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Introduction 


D esde el primer instante en que empezamos a conocer, estudiar y profundizar en Power 
Pivot, la construccion de modelos de datos junto con el Lenguaje DAK] jfue reveladory 
extraordinario! un viaje estremecedor, fantastico y palpitante; es como si nos hubieran 
traido una tecnologia de veinte anos en el futuro para utilizarla hoy en dia. La capacidad de 
resumir cantidades masivas de datos, crear expresiones de todo tipo para extraer gemas de 
informacion, acompanado de la posibilidad de crear tablas dinamicas como nunca antes se 
habia sonado, era el primer indicio de que Power Pivot era el poder para las personas, la 
herramienta del futuro puesta en nuestras manos ahora. jBusiness Intelligence para Todos! 

^Exageramos con esto?- Por supuesto que no, despues de casi dos anos en una fase academica 
para dominar Power Pivot y el Lenguaje DAX llena de descubrimientos, llego la epoca de 
aplicacion; alii fue aun mas increible, la facilidad para resolver problemas, construir modelos 
en Excel y/o cuadros de mando para que ayudaran a la toma de decisiones empresarial que 
funcionara de manera autonoma y acertada, es una catapulta a otra dimension. 

Power Pivot admite tomar multiples origenes de datos, que pueden venir de diversas fuentes e 
integrarlos de una manera optima, elegante y sencilla, permitiendo actualizaciones con un par de 
clics, para posteriormente poder tomar estos datos y obtener informacion de alto valor de una 
forma tan rdpida que es oportuna para la toma de dedsiones, ademas de acertada para aplicarla 
a la realidad y oriente en un camino positivo los objetivos de negocio. 

Entonces, Power Pivot permite tomar decisiones, con bases fundamentadas, que si llega un 
momento critico puede llevar a una mayor eficiencia en las operaciones, impactar en mayor 
rentabilidad para la empresa, o incluso, incrementar el nivel de satisfaccion del cliente. 
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Con todo el aprendizaje intenso, pero emocionante durante casi dos anos, acompanado 
ulteriormente de una epoca de palpar con nuestras propias manos aplicaciones reales, nos 
dimos cuenta que no nos podiamos quedar con esto. 

Sorprendentemente hoy en dia Power Pivot, antes escrito como: PowerPivot sin espacios, y el 
DAX engine son poco conocidos e inconscientemente ignorados, a pesar de ser una pieza 
revolucionaria, que ha estado presente desde finales del ano 2009, muchi'simas personas que 
se pueden beneficiar con Power Pivot y escalar profesionalmente de forma abrumadora, no saben 
que existe. jDe Verdad! 

Oueremos aportar nuestro pequeno granito de arena para cambiar esto y, lo que es seguro es 
que tu mi amigo@, ya no eres unas de estas personas que estan dejando pasar tiempo sin 
conocer y dominar las maravillas de Power Pivot y el DAX Engine. La pieza magica que cambia 
por completo las reglas del juego. 

El presente libro es una guia paso a paso por Power Pivot, la construccion de modelos 
sofisticados y completos, al lado del potentisimo lenguaje DAX (Expresiones para Analisis de 
Datos) que abre las puertas a universos paralelos llenos de nuevos colores y experiencias. Todo 
eso se abarca de manera detallada desde los fundamentos basicos hasta los aspectos mas 
avanzados y complejos, todo orientada a extraer informacion valiosa para la toma de 
decisiones, en definitiva, Inteligencia de negocios, Business Intelligence o Bl. 
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Acerca De Este Libro 

jEstudia, Practica, Interioriza y Aplica! 


Este libro es una guia paso a paso sobre Power Pivot, construccion de modelos de datos y el 
lenguaje DAX; desde sus fundamentos esenciales hasta los conceptos profesionales, todo esto 
con la mira puesta en desbordartodo el poder de esta herramienta de inteligencia de negocios. 

Por lo anterior, este NO es un libro para leer y pasar pagina por pagina; jOh! No, No, No, No, No. 
Este es un texto para estudiar, practicar, interiorizar y aplicar; para que a si, puedas ser un gran 
maestro en Power Pivot, debes estudiar la tematica detenidamente sin dejar ninguna fisura, 
practicar con los archivos proporcionados, por ti mismo y experimentar con ellos, mirar otros 
escenarios, variar los presentados y generar soluciones alternas, encontrar y arreglar errores 
que se te presenten. Todo esto te ayudara a interiorizar la tematica, para que posteriormente lo 
puedas aplicar en tu trabajo, en tu dia a dfa. 


Recuerda: / Estudiar, Practicar, Interiorizar y Aplicar! 
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i Es Este Libro para Ti? 


Este libro esta orientado hacia los usuarios de Excel que quieran catapultarse a otra dimension 
con miras a aprender una herramienta que les permita tener un proceso de toma de decisiones 
certero, con lo cual tambien va enfocado a: gerentes, ingenieros, gerentes de proyectos, 
emprendedores que quieren ver insights en sus metricas o cualquier persona que tenga 
enfoque al alcance de objetivos. 


Todo profesional que quiera desatar un enorme poder y desea potenciar 
Excel como nunca antes, tambien es un libro perfecto. 


Versiones De Software 

Microsoft Office 2016 y 2013 • Este Libro NO Aplica para Excel 2010 


Las tematicas aqui tratadas son desarrolladas en Excel 2016 donde se dejan referencias claras 
para uso en Excel 2013 si hay diferencias considerables, por lo que seria ideal que el lector 
contara con algunas de estas dos versiones: Excel 2013 0 2016, cuya edicion incluya Power 
Pivot A continuacion, las resaltamos: 


■ Para Excel 2013: Power Pivot solamente esta disponible para la version de Office 
Professional Plus (Se Activa en complementos COM), si tienes Standalone u Office 365 
Professional Plus, puede ser instalado. 



■ Para Excel en Microsoft Office 2016: Power Pivot esta disponible en diferentes 
ediciones, estas son: Office 365 Enterprise E2, Office 365 Enterprise E3, Office Professional 
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Convenciones Usadas En El Libro 


Ayudas Visuales y Otros Elementos 


A lo Largo del libro, utilizamos cuadros con un borde cafe tenue que en su parte izquierda tienen 
un icono, esto lo hacemos para resaltar alguno de los siguientes aspectos: 

■ Pausemos un Momento: Este cuadro lo tomamos como una pausa activa para senalar 
tematicas externas, otros recursos, aclarar conceptos, resaltar conclusiones de lo que se 
esta tratando en este momento o mencionar algun punto relacionado con el tema o 
capitulo. 


Pausemos un Momento 



Podemos decirte con total sosiego que este capttulo y los posterlores 
no son nada complejos, a pesar en entrar en el mundo de lo 
avanzado, mas bien, lo que si requiere es de especial atencion y un 
buen cafe para estar activos. 


• jToma Nota!: Como su nombre lo indica, este es un cuadro clave para recalcar cosas 
importantes, puede ser un concepto, una conclusion, un ejercicio, etc. 


jToma Nota! 



No confundas la funcion VALUE con VALUES, aparte de diferenciarse en 
la S al final, son funciones bien diferentes. VALUE es una funcion de 
conversion que transforma un valor de tlpo texto en numero; mientras 
que la funcion VALUES retorna la llsta de elementos unicos. 
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■ Referenda Cruzada: Este cuadro aparece muy pocas veces a lo Largo del Libro, no 
obstante, tiene como objetivo marcar a otro libro o articulo, en miras a brindar fuentes 
para profundizar en La tematica que se esta tratando si se quiere ir aun mas alia. 


Referenda Cruzada 


© LIBRO: EL ADN de Power Bl (.com) y Desktop - Miguel Caballero & Fabian 
Torres. Este libro tiene la particularidad que aparte de dedicarse 
fuertemente a visualizacion de datos y Bl, pasa un buen rato en la 
immersion de las funciones de filtro mas avanzadas (Las funciones de 
tablas complejas) 


A parte de los cuadros encontraras notas en los extremos de las paginas cuyo fin es: completar, 
apoyar, advertir, reforzar o recalcar la tematica tratada. 


NOTAS 


Recuadro jToma Nota!: Son notas 
claves, practicamente, saca tu cuaderno de 
apuntes de Power Pivot y DAX y anotala. 


Notas Extra: Completar, apoyar, 
advertir, reforzar o recalcar. 


o 
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jToma Nota! 

Las fundones de agregacion siempre se aptican a la columna ecrtera 
yse expander si se ogregan mas registros, de esta manero coda una 
tended un resultado distmto (Entre Funciones de Agregacion). En la 
figura anterior todos los resuttados son iguales porque se apEco a lo 
columna complete y permanece constante en todas las celdas. 


Funciones de Conteo (De las Funciones Estadisticas) 

Las funciones de conteo son aquellas que nos sirven para, valga la 
redundancia, contar todos los elementos de una columna o tabla 
que cumplan con ciertas caracteristicas, hay cinco claves que 
listamos inmediatamente. 


NOTA 

Todas las funciones de 
conteo descritas en la 
tabla son de agregacion, 
sin embargo, no todas las 
funciones de agregacion 
se listaron alii, las que no 


necesitan de cierta teoria 
. comprenderlas 
te por to que 
a abarcan en capltulos 


COUNT 


Funciones Claves de Conteo 


Cuenta el numero de ce 


io columna que 


COUNTA Cuenta el numero de celdas que denen numeros, 

votores logicos y texto en columna. 

COUNTBLANK Cuenta el numero de celdas vaa'as en una columna 
COUNTROWS Cuenta el numero de filas que tiene una tabla 
DISHNCTCOUNT Cuenta el numero de celdas diferente s en una 
columna. 

Para simptificar, de ahora en adelante cada vez que creemos una 
medida aparecerS asi: 


Nombre_Tabla[Nombre Medida]:=FUNCl6N(Tabla[Columna]) 
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Tambien podras notar diversos elementos visuales de apoyo, cuya meta es hacer la explication 
lo mas amena, detallada y amigable para que asi la tematica presentada se puede absorber con 
facilidad. 


AYUDAS VISUALES 


0 ADN OE Power Pivot 


o 


Hay Elementos enfocados a atraer la atencion en 
aquellos detalles que no se pueden dejar pasar por alto. 


Elementos Visuales de Apoyo para recorrer paso a paso lo 
que esta sucediendo y asI brindar el detalle suficiente para 
absorber la tematica de la mejor manera posible. 


iEsperabas un error no es asl?- Pero. todo lo contrario, ha ocurrido 
algo bien intcresanto, miremos las buenas nuevas. 


TABLA_CategoriaDeProductos, Descuentos, SKU Productas, Calcndario | Tobias de Busqi 


iitM Qicmm? 



O 


,DE NINGUNA MANERA! jOe l 'entail? Podemos oprecior que las das 
relaciones ester presenter entre el par de taPias (Pedidos y 
Caleodano), donde la primero es una lined soicdo. mientros que lo 
reden creoda es una lined punteada. esto signifca que dicha reladon 
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1 El Arte de las Medidas 

Funcibn All 

EXCEPT 

Definiridn 

La funcibn ALLEXCEPT remueve ciertas coordenadas (pltros) 

durante las etapas del proceso de cilcuto para una medida, 

excluyendo aquellos campos que especifiquemos. 

Sintaxis 

ALLEXCEPT(<tabla>; Columna;...) 

Argumentos 

La funcibn ALLEXCEPT tiene un numero indefinido de argumentos 

donde on el primer de ellos indicamos la tabla a remover todos sus 

filtros, a partir del segundo argumentos vamos indicando las 

columnas que queremos mantener sus coordenadas. 



Tabla Una tabla para remover coordenadas 

columna columna para NO remover Coordenada 


Utilizando la funcibn ALLEXCEPT la media quedarla de la siguiente 

manera: 


TABLA_Pedidos(lngresos GENERAL]:- 

CALCULATE([lngresos): 

ALLEXCEPT(T ABLA_Pedidos; ___ 


TABLA_Pedidos(Fecha de Envio (afio)l: 

TABLA_Pedidos[SKU] 

) 

) 


Por otra parte, la funcibn ALL5ELECTED le brinda dinamismos a un 

reporte. puesto que nos permite detectar parbmetros 

seleccionados en la tabla din£mica. 


ELEMENTOS QUE RESALTAN 


Hallaras tablas para resumir, compactor funciones y 
tematicas especlficas. 


Encuentras las expresiones DAX y Sintaxis con un 
fondo para identificacion agil. 




mms ®iB|o 






















XXII 


Como esta Organizado el Libro 

Capitulo a Capitulo 


CAPITULO 1 ' Fundamentos y Conceptos Esenciales. 

En este capitulo mostramos al desnudo todas las limitaciones y dificultades de las tablas 
dinamicas, hasta el punto de desbaratar lo que es la funcionalidad mas importante de Excel, 
pues de esta manera entenderemos como tecnologias tales como Power Pivot surgen como un 
salvavidas, ademas, teniendo esto en mente se hace un recorrido a traves del nuevo armamento 
de posibilidades que ha puesto en nuestro arsenal Microsoft. 

Capitulo 2 < Tablas Dinamicas a la Velocidad de La Luz (Opcional) 

Es importante para el desarrollo del libro que se tenga un conocimiento intermedio en tablas 
dinamicas, de hecho, es un requisito de este texto, a pesar de ello dedicamos este capitulo al 
lector que por distintos motivos no tiene un nivel basico en esta tematica, para resaltar aspectos 
sobre esta funcionalidad que seran transcendentales en diferentes momentos. Tambien puede 
servir como un repaso fugaz para refrescar la tematica de tablas dinamicas si se desea. 

CAPITULO 3 Interfaz y Propiedades de Power Pivot. 

Para que el viaje a traves del maravilloso mundo de Power Pivot y el lenguaje DAX sea 
satisfactorio, es necesario familiarizarnos con la interfaz y sus diferentes elementos, ademas de 
destacar propiedades importantes exclusivas de la herramienta. 


CAPITULO 4 • Agregar Bases de Datos. 

Power Pivot pone a nuestra disposicion la posibilidad de tomar bases de datos de multiples 
fuentes como: Access, Azure Market Place, SQL Server, entre muchos otros; para despues 
integrarlos mediante relaciones. Este capitulo se dedica a explorar los origenes de datos mas 
comunes y como cargarlos a Power Pivot viendo sus ventajas y desventajas, lo cual es un 
aspecto supremamente importante cuando se desea realizar modelos de datos complejos y 
optimos. 

mm i®§§ 
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CAPITULO 5 Entretejiendo Tablas: El Modelo de Datos. 

Vemos como relacionar las tablas con Power Pivot y un caso especial con Power Query, tambien, 
estudiamos que es DAX y cual es la nomenclatura de tablas en este lenguaje, para asi dar el 
primer vistazo a los dos tipos de calculos personalizados: Columnas Calculadas y Medidas. 

CAPITULO 6 8 Bienvenido al Pais de las Maravillas: El Lenguaje DAX. 

Comenzamos a entrever el gran potencial del lenguaje DAX junto con las medidas, viendo las 
funciones mas comunes, los tipos de datos, manejo de errores y buenas practices para formulas 
extensas. 


CAPITULO 7 68 Back-Office, Contextos: DAX Engine Detras de Camaras. 

Capitulo que supone un punto de inflexion ya que constituye las bases teoricas para empezar 
a recorrer las tematicas avanzadas en DAX y Power Pivot en general. Se estudian 
detalladamente los distintos tipos de contextos y constrains. 

Capitulo 8 El Arte de las Medidas. 

Habiendo adquirido las bases teoricas, este capitulo recorre un buen numero de funciones 
avanzadas en DAX mediante un estudio minucioso acompanado de multiples ejemplos 
aplicados. Uno de los capitulos mas importantes y criticos para emprender el camino a dominar 
DAX y el analisis de datos como unos cracks. 

CAPITULO 9 Funciones de Filtros y perspectivas del Lenguaje. 

Siguiendo las lineas del capitulo previo, veremos aspectos complejos, pero de gran relevancia 
para crear modelos de datos mas robustos y suficientemente autonomos, ademas, se explora 
el lenguaje DAX desde diversas perspectivas para aterrizar un poco mas lo tratado e interiorizar 
todos los conceptos avanzados vistos hasta el momento. 
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CAPITULO 10 • Time Intelligence: Calendarios Estandary Personalizados. 

Un capitulo vital, ya que trata como manipular las fechas y en general el tiempo en las tablas 
relacionadas como nunca antes. Se aborda como construir y emplear calendarios estandar y 
personalizados. 

CAPITULO 11 • Tablas Slicers: Parametros de entradas del usuario. 

Una tematica divertidisima e igualmente importante, ya que abarca como recibir datos por parte 
del usuario para que se vean reflejadas instantaneamente en tablas de Power Pivot. 

CAPITULO 12 • Multiples Tablas Base y Relaciones Avanzadas. 

Un capitulo dedicado a estudiar como manejar multiples tablas con alta densidad de datos, lo 
cual incide en la profundizacion de relaciones avanzadas. 

CAPITULO 13 • Jerarquias & KPIs: Key Performance Indicators. 

En este capitulo se exploran dos potentes funcionalidades de Power Pivot, enfocadas en 
mejorar la experiencia de usuario: hablamos de las jerarquias, que facilitan la busqueda de 
informacion y los KPIs, que son elementos visuales que ayudan a monitorear indicadores, entre 
otros usos. 


Capitulo 14 • DAX como Lenguaje de Consulta. 

Como le indica el nombre, estudiamos como utilizar DAX como leguaje de consulta (As a Query 
Lenguague) a un nivel basico e intermedio. 
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Como Utilizar Este Libro 

Guia de Estudio y Practica, Tambien de Consulta 


Este Libro esta estructurado para ser estudiado capitulo a capituLo minuciosamente, en donde 
en cada uno se asume que se ha entendido el capitulo previo a la perfeccion, pues Power pivot 
y el lenguaje DAX lo requiere, para eventualmente llegar a las tematicas complejas y avanzadas. 
jPara llegar a los rincones mas magicos! 

Estudiar los capitulos de manera aleatoria sera confuso e inevitablemente frustrante, debido a 
que si no se tiene pleno conocimiento de temas previos es muy dificil entender los mas 
adelantados. 

Una vez termines este libro, puedes utilizarlo como consulta para refrescar conceptos, estudiar 
nuevamente puntos especificos o enriquecer ciertas tematicas con una nueva lectura, pues 
desde este punto de vista ya tienes todas las bases solidas y el conocimiento. 


Perfilando Tu Viaje a Traves De Power Pivot 



A? 


i Ipi 




t 


De lo anterior (Como utilizar este libro) se pueden hacer 
excepciones, como a casi toda regia, ya que si el lector 
tiene un conocimiento basico de Power Pivot en: 
Cargar Bases de Datos de diversas fuentes, Relacionarlas, 
Creacidn de Medidas y Columnas Calculadas ; entonces 
puedes empezar a partir del capitulo 6, pero de alii en 
adelante se recomienda que sea en orden. 


Si tu conocimiento es a prueba y error, te 
recomendamos darles un vistazo a los capitulos 
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■ Perfil #1: A partirde Cero, Capitulol,2,3,4,5, ..14 en order i. 

■ Perfil #2: Conocimiento Basico, Capitulo 6,7,8,9,10,...14 en orden. 


Feedback y Actualization de Contenido 


Tu como el lector de este libro eres uno de los criticos mas valiosos, por esto es muy importante 
para nosotros escuchar de tu parte cualquier opinion, critica, correccion, sugerencia, mejoras, 
ilustraciones, consejos, complementos, etc. En cuyo caso puedes escribirnos a cualquiera de 
los siguientes correos electronicos: 

■ E-mail 1: excelfreebymcs@gmail.com 

■ E-mail 2: feedback@eladndepowerpivot.com 

Tambien te invitamos a que una vez finalices la lectura de este libro o en el momento que lo 
consideres oportuno nos regales tu feedback, es invaluable para nosotros, puedes hacerlo al 
siguiente correo: 

■ E-mail 2: excelfreebymcs@gmail.com 

Actualizacion: Cada vez que se hagan correcciones relevantes o se agregue material, recibiras 
via correo electronico la ultima copia. Esto sera asi indefinidamente hasta que llegue en algun 
momento en el futuro la publicacion de una segunda edicion. 


<jQue Piensas de Este Libro? 

Agradeceriamos de todo corazon que nos dieras a conocer tanto a nosotros como a toda la comunidad 
Que piensas y como ha sido tu experiencia con este libro, cuando lo consideres necesario. 
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Material Complementario 


El ADN de Power Pivot cuenta con todos los archivos utilizados a lo largo del texto, dejando 
tanto los archivos iniciates para que el lector pueda seguir paso a paso y en paralelo las diversas 
tematicas, ademas, cuenta con los archivos finales para poder contrastar y apoyarse en 
monnentos de dificultad. 

Puedes Descargarlo en: 


COMPENDIO DE ARCHIVOS 



Dropbox 


Compendio de Archivos: 

Incluye Archivos Iniciales, Finales e llustraciones Extras 
(ClicAqui Para Descargar) Contraseha: micdaadnpwpefb9926*d2 


Te recomendamos que descargues los archivos, repliques lo visto y practiques. 


MINI-SERIE EN VIDEO 



Nociones Power Pivot: 

Mini-Serie enfocada a explorar algunas de las bondades de 
Power Pivot. 

(ClicAqui Para Ver) 100% Gratuita. 


Serie: Nociones Power Pivot (Sino la has visto, ve y mirala ahora mismo) -100% Gratuita. 
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jIMPORTANTE! Tener esto en cuenta antes de Empezar 


SEPARADOR DE LISTA 


En este libro utilizamos el separador de lista: (;) tanto para los argumentos de las formulas 
normales de Excel como las formulas DAX de Power Pivot. Si tu computador esta configurado 
para utilizar (,) como separador de lista te recomendamos no cambiarlo, puede ser tentador 
hacerlo para copiar las lineas DAX y pegarlas para que funcionen directamente, no obstante, 
recomendamos NO hacer esto si es tu caso, recuerda que este es un libro, para: estudiar, 
practicor, interiorizar y apiicar. 


IDIOMA DE FUNCIONES 


El idioma de las funciones DAX es en ingles, independiente de la configuracion regional y de 
idioma, igualmente Power Pivot cuenta con sus propias configuraciones de lenguaje, sin 
embargo, estas aplican solo a comandos y elementos de la interfaz grafica de usuario y, no para 
el lenguaje DAX. 

Portal motivo las funciones a lo largo del libro son en ingles, si encontramos una alternativa o 
Microsoft proporciona la traduccion haremos las correspondientes equivalencias. 







La Presente Pagina se ha dejado en Blanco de forma deliberada. 




Capftulo 1 


Fundamentos y Conceptos Basicos 
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Verdad Incomoda, Limites en Reportes 


NOTA 

No serfa demasiado 
drastico decir que, para los 
analistas, consultores, 
gurus en Excel que tienen 
un dominio absoluto en 
tablas dinamicas han vivido 
con este problema 
tranquilamente, quiza con 
demasiada tranquilidad, no 
es de sorprenderse, pues 
Excel brinda un sinffn de 
funcionalidades para 
abordar este problema por 
fuera de la caja y llegar una 
solucion. No obstante, si 
que requiere de 
manipulaciones en cierta 
medida extremas y nunca 
es lo mas eficiente. 


Las tablas dinamicas, son sin duda alguna, la piedra angular para 
crear reportes interactivos y potentes; su dinamismo, velocidad y 
versatilidad para hacer resumenes, la convierten en el arma mas 
poderosa, en la "artillena pesada", en nuestro arsenal de Excel. Esta 
trituradora de datos permite entender que esta sucediendo en 
nuestro negocio en cuestion de minutos, llevar a cabo acciones y 
direccionar hacia los objetivos establecidos. 

Lo anterior es la razon por la cual es una funcionalidad tan 
demandada en el catalogo de habilidades de un profesional. Sin 
embargo, una oscura verdad aflig e(ia) esta sofisticada 
funcionalidad. 

jLa Oscura Realidad! 

Para resumir esta limitacion, jesta oscura verdad!: Las tablas 
dinamicas tienen una caja de herramientas para crear formulas o 
calculos personalizadas tan diminuta que practicamente es nula, y 
ata nuestras manos al punto de no poder "extraer" perlas de 
informacion de la "mina de datos" que la alimenta. 

Para entender esta limitacion, vamos a desglosarlo en cuatro partes 
fundamentales: 


■ Limitaciones en Funciones de Resumen 

■ Limitaciones en Visualizacion de Valores 


■ Limitaciones en Elementos y Campos Calculados 



Limitacion para alimentarse con datos de entrada del 
usuario 
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Limitaciones en Funciones de Resumen 

Cuando creamos una tabla dinamica y agregamos un campo al area 
de valores tenemos varias posibilidades para resumir los datos que 
a Ilf se presentan, por ejemplo: Sumo o Promedio. Estas 
posibilidades que ofrecen las tablas dinamicas se denominan 
funciones de resumen, existen once de ellas. 



Figura 1.1- Funciones de Resumen 



Pausemos un Momento 

En este libro, asumimos que el lector cuenta con un conoclmlento por 
lo menos intermedio en tablas dinamicas de Excel si el lector no 
domina esta funcionalidad le recomendamos que estudie el capltulo 
dos: Tablas Dinamicas a la Velocidad de la Luz., asl como ir a las 
referencias que se senalan en el mismo. 
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jTriste pero cierto! jTriste pero cierto! Y aunque Las once funciones de resumen 

propuesta por las tablas dinamicas son Las mas comunes, no es tan 
extra no encontrar situaciones en las cuales requerimos de otras 
alternativas. Toma por ejemplo la siguiente tabla de datos. 


- 1 - [ZA - 1 -| T |-| T |-i T 

9 Vilma 

Prueba Italia 

3.9 

6 Fausto 

Prueba Ale mania 

8.4 

10 Greg 

Prueba Italia 

3.9 

4 Alexa 

Prueba Portugal 

7.0 

3 Hank 

Pruba Espana 

8.8 

1 Eddy 

Pruba Espana 

6.0 

10 Greg 

Prueba Italia 

4.7 

1 Eddy 

Prueba Portugal 

6,9 

8 Hank 

Pruba Espana 

4,8 

10 Greg 

Prueba Portugal 

6.2 

6 Fausto 

Prueba Portugal 

4.2 

3 Pedro 

Prueba Ale mania 

6.9 

6 Fausto 

Prueba Italia 

3.3 

9 Vilma 

Prueba Italia 

7.5 

8 Hank 

Prueba Ale mania 

5.9 


Figura 1 . 2 -Tabla de Datos Certamen 


Dicha tabla contiene la duracion de varias pruebas en distintos 
certamenes de ciclismo de velocidad, supongamos que de ella 
queremos ver: la duracion mas pequena, la segunda duracion mas 
pequena y la tercera duracion mas pequena de cada uno de los 
certamenes, para asi establecer tres categorias de rendimientos. 


iComo hacemos esto? Es decir, tenemos a nuestra disposicion la 
funcion Min quien nos daria la primera parte (la duracion mas 
pequena) pero, icomo detectamos el segundo y tercer mas pequeno?, 
ya que en las funciones de resumen no contamos con 
K.ESIMO.MENOR o algo similar. / Formulas las unica Salida! 
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A continuacion, se presenta nuestra intencion de tabla dinamica. 


Certamen 

D 

1 ° - Primera 

Duration Mas Veloz 

2°-Segunda 

Duration mas Veloz 

3° - Tertera 

Duration mas Veloz 

Pruba Espana 

4.8 



Prueba Aleman ia 

Pmeba Italia 

3.2 

3.3 



Prueba Portugal 

3.4 




<jC6mo encontrar el 
segundo, tercero, etc. 
En una tabla 
dinamica? <;De la 
misma manera como 
encontrar 2,3, mayor? 


Figura 1.3- Intencion de Tabla Dinamica con, primer, segundo y tercero menor 


Strike One Tablas Dinamicas. Contar con solo once funciones de Strike One 

resumen pone el primer nudo a nuestras manos para moldear los 
tipos de calculo a nuestra necesidad. 


Limitaciones en Visualizacion de Valores 

Aparte de poder resumir los datos con cierto calculo, las tablas 
dinamicas tambien brindan la opcion de ver esos valores de 
numerosos modos, dicho de una manera diferente, de visualizar los 
datos con una segunda operacion aplicada a la funcion de 
resumen. Por ejemplo, si tenemos la funcion de resumen Suma, 
podemos indicar posteriormente que queremos visualizar esos 
valores de tal forma que se presenten como un porcentaje del total 
general, con lo cual la segunda operacion seria dividir "El valor de 
la celda en la tabla dinamica" entre el "total general de la tabla 
dinamica actual" y con ello, mostrarlo con formato de porcentaje. 


Tenemos a nuestra disposicion catorce tipos de visualizacion de 
valores, a saber: 


1 ) 

2 ) 





Porcentaje el Total General 
Porcentaje del Total de Columnas 
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NOTA 

Un usuario de nivel 
intermedio en tablas 
dinamicas conoce 

bastante bien los tipos de 
visualization de valores, 
sin embargo, el tipo de 
visualization de valor 
fndice es bastante 
desconocido y poco 
usado. 


3) Porcentaje del Total de Filas 

4) Porcentaje de (Expresar un item como porcentaje de otro) 

5) Porcentaje del Total de Filas Principales 

6) Porcentaje del Total de Columnas Principales 

7) Porcentaje del Total Principal 

8) Diferencia de 

9) Porcentaje de la Diferencia de 

10) Total en 

11) Porcentaje del Total en 

12) Clasificacion de Menor a Mayor 

13) Clasificacion de Mayor a Menor 

14) Indice 


Si tu, mi amigo lector, te 
encuentras entre los gue 
no conoce el gran poder 
oculto de este tipo de 
visualizacion de valor, te 
recomiendo el siguiente 
video: 



Indice v Su Poder 


Ahora, toma la siguiente tabla de datos. 



ID de Cliente 

|V| ID Producto |^j Codigo 

Pedido |V| Fecha 

P7| Unidades ($) p^T| Ingreso 

W pi 

181215 

IP2 

158957 

sabado, 8 de Enero de 2005 

22 

22000 

181215 

IP3 

158958 

sabado, 8 de Enero de 2005 

20 

24000 

181215 

IP4 

158959 

sabado, 8 de Enero de 2005 

20 

28000 

181215 

IP5 

158960 

sabado, 8 de Enero de 2005 

16 

25600 

181215 

IP6 

158961 

sabado, 8 de Enero de 2005 

16 

28800 

181215 

GSI 

158962 

sabado, 8 de Enero de 2005 

22 

18700 

181215 

GS2 

158963 

sabado, 8 de Enero de 2005 

12 

11100 

181215 

GS3 

158964 

sabado, 8 de Enero de 2005 

22 

22000 

181215 

GS4 

158965 

sabado, 8 de Enero de 2005 

24 

25800 

181215 

GS5 

158966 

sabado, 8 de Enero de 2005 

22 

25300 


Figura 1.4- Tabla de Datos Pedidos 


Como podemos observar tenemos ciertos productos y una fecha 
que indica el dia que se vendido una o varias unidades, si nos 
detenemos un segundo, podriamos pensar en hacer un calculo que 
nos diga el numero de dias en que hubo ventas, si bien, la tabla 
tiene aproximadamente 25K de registros (filas), es probable que 
tenga un numero mucho menor de fechas unicas, dado que un dia 




en especifico se pudieron hacer ventas de productos diferentes. 






















El ADN DE Power Pivot 




Es mas, en la figura anterior que presenta la tabla se puede ver que 
los primeros siete registros corresponden a la misma fecha, esto 
corresponderia a una fecha unica, entonces se contaria uno para 
estos siete registros y asi cada vez que encuentre una fecha 
diferente. 

Oue tal si quisieramos hacer un calculo personalizado que nos 
dijera el numero de fechas unicas, pues las tablas dinamicas nos 
dan una bofetada para despertarnos, ya que este no se puede, por 
lo menos sin aplicar potentes trucos y funcionalidades diversas 
para lograrlo. 

Ahora bien, vamos un paso mas alia; que tal si quisieramos un tipo 
de visualizacion de valor del siguiente estilo: % del Calculo 
Personalizado (Porcentaje del Calculo Personalizado). 


% del Calc. Person. 


Vator delaCeldaActualen_la Tabla Dindmica 

Calculo Personalizado: Numero de Fechas un icas 


jSi que menos! Pero admitamoslo seria un calculo y tipo de 
visualizacion de valor magnifico, aparte de super util. 

Strike Two Tablas Dinamicas. Contar con solo catorce posibilidades 
de tipos de visualizacion de valores, japesta!, nuevamente agrega 
otro nudo, y esta vez, mas apretado a nuestras manos para poder 
realizar un analisis mas profundo y sofisticado a nuestros datos. 



XlOO 


Strike Two 
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Limitaciones en Elementos y Campos Calculados 

Las tablas dinamicas permiten, por supuesto, extender nuestros 
calculos para anadir datos basados en operaciones entre campos o 
elementos existentes. 


Aqui podemos insertar 
funciones para hacer 
operaciones entre los campos 
disponibles que proporciona el 
origen de datos, sin embargo, el 
uso de funciones es 
supremamente limitado, ya que 
este motor de funciones es 
completamente independiente 
del que utilizamos normalmente 
en la hoja de calculo, para 
ponerlo simple, podemos usar 
SUMA, PROMEDIO, CONTAR, 
pero funciones potentes como: 
BUSCARV, 

SUMAR.SI.CONJUNTO, etc. 
estan porfuera del alcance. 


Insertar campo calculado 


X 


Nombre: 

Formula: 


Campol| 

V 

= 0 

_^_ 



Sumar 



Eliminar 


Nombres 

Apellidos 

E-mail 

Plataforma 

Afiliados 

Fecha 

Ingreso 


Insertar campo 


Aceptar 


Cerrar 


Figura 1.5- Cuodro de didlogo poro Insertar Campos Calculados 


NOTA 

El lector puede encontrar el 
ejemplo del ultimo parrafo 
extrano y, hasta sin utilidad, 
no obstante, como veremos 
en capftulos posteriores el 
uso de este tipo de 
escenarios es bastante 
conveniente y util para crear 
reportes de tablas dinamicas 
mas robustas y potentes. 


Pero tiene bastantes barreras, basicamente porque: 

■ No se pueden utilizar referencias a celdas 

■ Numero limitado de funciones a nuestra disposicion 

■ No se pue hacer referencia a los totales generates 

■ No se puede hacer operaciones entre elementos de distintos 
campos 

Por ejemplo: si quisieramos hacer un calculo, el cual hiciera la suma 
de todos aquellos que cumplan con uno o mas criterios, para asi 
crear un filtro interno y darle al usuario una experiencia con Slicer y 
campos de filtro mas comoda y acotada. Pero evidentemente lo 
anterior no es posible con campos calculados. 
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Strike Three Tablas Dinamicas. jYOUR OUT PIVOT TABLES! Tu Strike Three 

tiempo como el mas grande bateador para crear reportes en Excel 
ha terminado. jY porsifuera poco tenemos esta otra iimitacidn! 

Limitaciones para Recibir Datos de Entrada del Usuario 

Supongamos que queremos darle la posibilidad al usuario final del 
reporte de tabla dinamica la alternativa de ver en ella solamente 
aquellos productos que tienen un precio mayor o igual al deseado, 
es decir, al precio que el usuario final guste, realizar esto con tablas 
dinamicas si que es posible, sin embargo, con uso de macros o 
funciones porfuera de la tabla dinamica, pero internamente de una 
manera amigable y sencilla no es posible y no es tan evidente. 


Las Tablas Dinamicas han MUERTO!? 

Significa eso entonces que las tablas dinamicas no son la maravilla 
como todo el mundo presume. Pues bien, absolutamente NO. 
Incluso con las limitaciones que tienen, lo que podemos hacer con 
esta funcionalidad es amplio y agil, es dificil imaginar todas sus 
bondades. 


Ademas, presta atencion a este parrafo: Power Pivot corta estos 
nudos que tenian las tablas dinamicas y pone en nuestras manos 
una poderosa arma en nuestro arsenal de Excel que unicamente 
esta limitada por nuestra imaginacion; todo lo que queramos hacer, 
todos los calculos que queramos desarrollar son ahora rapido, 
posible y sin temor a exagerar, sencillo y divertido, adicionalmente 
brinda muchas mas posibilidades. Como super plus: Power Pivot se 
extiende a otras tecnologias como: SSAS Tabular y Power Bl. "Es 
como un sueho para la inteligencia de negocios hecho realidad.'' 


iATENClON! 






Capitulo 1 / Fundamentos y Conceptos Basicos 



The Big Six, "Los Seis Grandes" 

The Big Six, es La denominacion que nosotros le damos a Las seis 
funcionaLidades que han tenido La trascendencia mas importante 
en Los ultimos siete anos. “Las mas importantes e influyentes en 
Microsoft Business InteLLigence Tools". 


iQuienes son los 
BIG Six? 


NOTA 

Power Bl Desktop y Power 
Bl (.com) pertenecen a 
otro ambiente, es decir, a 
otro producto o programa 
que es distinto de 
Microsoft Excel, sin 
embargo, todos son parte 
de una misma familia: 
Microsoft Business 

Intelligence o "Self- 
Services Bl", estas 
tecnologfas tienen como 
meta construir complejas 
estructuras de datos y 
analizarlas eficientemente; 
como, por ejemplo, tablas 
y graficos dinamicos. 


iCuales Son? 


Tabla de Los integrates del Big Six 


Funcionalidad 


Power Query 
Power Pivot 
Power View 
Power Map 
Power Bl Desktop 
Power Bl (.com) 


Nombre Actual (Office 20/6) 


Obtener y Transformer 
Power Pivot / Mode/o de Datos 

Mapas 3D 


En seguida vamos a ver una descripcion para ver que rol juega cada 
uno en La mesa de Business InteLLigence, como cada uno es un 
eslabon para hacer inteligencia de negocios eficientemente. 

Sin embargo, antes de entrar en ello, es importante mencionar 
inmediatamente que: Power Pivot es el centro de todo T El principal 
y mas astuto estratega" en este proceso de tomar Los datos y 
transformarlos en informacion util, oportuna y accionable para La 
compahia. 
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Porque de las funcionalidades mas recientes 

Como se menciono en la nota anterior, "Los Big Six" estan 
repartidos en dos ambientes diferentes: Excel y Power Bl. 

La necesidad y surgimiento de ellos es facilmente entendible Por 
que? Lo resumiremos en los siguientes puntos: 

■ El BIG data (Volumenes masivos de datos) hoy en dia esta 
presente en todas partes, Excel solo cuenta con un poco mas 
de 1 millon de filas, con la cual la necesidad de expandir su 
capacidad no era opcional. 


■ Poder manipular y resumir cantidades masivas de datos 
tambien es vital, deriva del punto anterior, el propio Excel 
se vuelve lento cuando empezamos a trabajar con 100 mil 
filas de datos. 

■ La capacidad de tomar "Raw Data" de multiples fuentes y 
poder transformarlos y cargarlos tranquilamente. 

■ Presentar los datos de manera compacta mediante graficos 
y otros elementos de forma agil. 

■ La opcion de un paquete que NO este dirigido 

exclusivamente a profesionales IT (Information Technology) 
altamente especializados. 

■ La posibilidad de generar todo tipo de calculo 

personalizado, donde la unica limitante sea la necesidad y/o 
imaginacion de la persona. 


RAW DATA 

El termino "raw data" se 
utiliza para datos que no 
han pasado un proceso de 
limpieza, es decir, no han 
sido sometidos a ningun 
tipo de preparacion para 
que queden en un estado 
optimo y asf llevar acabo 
analisis a partir de ellos. 


Vamos a dar una brevisima descripcion de ellos segun su ambiente, 
empezaremos por los de Excel, estos son: 


Los Big Six que 
estan en el 
ambiente de Excel 


■ Power Query 

■ Power Pivot 

■ Power View 

■ Power Map 
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m 


Definicion de 
Power Query 


Power Query es una funcionalidad que pone a nuestra disposicion 
Las opciones suficientes para tomar Raw Data (datos no optimos 
para llevar acabo analisis acertados) consolidarLos, transformarlos, 
enriquecerlos, Limpiarlos, estandarizarLos y adaptarLos para que 
queden de forma optima y hacer un posterior analisis. En otras 
paLabras, Power Query prepara Los datos para eL consumo en Excel. 


jToma Nota! 



En la version de Excel 2016, Power Query pasa a hacer una 
funcionalidad embebida, asi como tablas dinamicas, graficos, etc. 
Ahora Power Query se encuentra en la pestaha DATOS grupo 
OBTENER Y TRANSFORMAR. Esto es un cambio respecto a las 
versiones anteriores que es un complemento con su propia PEST ANA. 


Definicion de 
Power Pivot 


Power Pivot es un potente motor de procesamiento de datos, que 
permite agrupar datos de multiples origenes, de una cantidad 
diversa de fuentes de una manera supremamente sencilla y a una 
velocidad sorprende, "como a la velocidad de La luz". Todo ello para 
obtener informacion de valor, accionable y oportuna para tomar 
decisiones en poco tiempo. 



iToma Nota! 


Power Pivot tambien se la llama El Modelo de Datos ambos son la 
misma tecnologia, sin embargo, hay que distinguirla del modelo de 
data interno, el cual es una parte pequerta de Power Pivot /El Modelo 
de Datos disponible para todas las ediciones de Excel. Tambien es 
importante anotar que Microsoft esta tomando Power Pivot y 
ahadiendolo a otros productos. 

-—— 
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Power View permite tomar todo ese procesamiento de datos, Power View 

donde se ha resumido y calculado para derivar informacion 

relevante y, presentarla (Mostrarla) mediante graficos, indicadores 

y distintas ayudas visuales para poder absorber la informacion de 

manera sencilla e intuitiva. Es una experiencia interactiva de 

exploracion de informacion. 


jToma Nota! 



En la version de Excel 2016, El comando Power View se tiene que 
anadir a la barra de herramientas de acceso rapido o crear el grupo 
artificialmente en opciones, personalizar cinta de opciones. Eso difiere 
a las ediciones anteriores donde se activaba en complementos COM 
en el cuadro de dialogo Opciones de Excel. 


Power Map es una funcionalidad de Excel que permite representar Power Map 

datos geograficos de forma bidimensional o tridimensional como: 

direcciones, codigo postal, paises, ciudades, vecindarios, calles y 

todo aquello que se pueda geo localizar en un mapa, ademas, de 

interaccion dinamica con datos temporales (Fechas). Power Map 

tiene el detalle de ser una funcionalidad enfocada a un nicho de 

mercado muy especifico, a pesar de ello, brinda otras posibilidades 

para analisis de datos (geograficos). 


jToma Nota! 



Power Map fue renombrado como Mapas 3D en la version de Office 
2016 y se puede encontrar en la pestaiia INSERTAR grupo PASEOS. 
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INTELIGENCIA DE 
NEGOCIOS 

Sin importar si es una 
multinacional, una 

pequena empresa. Bien 
sea el CEO en la compania 
o los cargos de niveles 
menores, cada minuto del 
dfa se estan tomando 
decisiones que tienen un 
impacto en el rendimiento 
de la empresa. En 
ocasiones las decisiones 
son de nivel estrategico 
que afectan a la compania 
completa, mientras que en 
otras ocasiones son de 
tipo tactico, afectando a 
una sola persona o un 
departamento completo 
en una ventana de tiempo 
pequena. La Inteligencia 
de negocios se pude 
pensar como la actividad 
de utilizar los datos de 
ayer y hoy para tomar 
mejores decisiones acerca 
del manana o cualquier 
actividad, herramienta o 
proceso utilizado para 
obtener la mejor 
informacion que apoye el 
proceso de toma de 
decisiones. 


EL Tejido Unificador de los "POWER EXCEL" 


A nosotros nos gusta llamar a los integrantes del Big Six que SE 
rigen bajo el ambiente de Excel como: "POWER EXCEL" todos ellos 
como pudiste detectar en la descripcion breve estan enlazados 
mediante un proceso estrategico para hacer inteligencia de 
negocios. Power Query adecua los datos para el consumo y poder 
hacer analisis optimo, despues Power Pivot los recibe para llevar a 
cabo este analisis de forma profunda, y finalmente Power View y/o 
Power Map proporciona todo lo necesario para mediante 
representaciones visuales entender de forma sencilla el analisis y 
poder tomar decisiones. 


Todos los Power Excel son una ficha para armar un rompecabezas 
de datos y ver claramente la informacion que esta oculta. 


Se puede 
optar por 
otras 

funcionalida 
des como: 
tablas y 
graficos 
dinamicos. 


STEP 04 

Power 



STEP 01 

Power Query 


STEP 03 

Power View 


STEP 02 

Power Pivot 


Esta pieza 
(ficha) no es 
Opcional. 


Algunas fichas para armar el rompecabezas de datos son 
opcionales, por ejemplo, si recibes los datos bien procesados y 
listos para su uso, lo cual no es muy comun, entonces Power Query 
puede ser omitido, o tal vez prefieras adecuarlos mediante 
formulas, funciones y oras funcionalidades clasicas de Excel; asi 
mismo Power View y Power Map pueden ser omitidos porque 
tambien es posible crear graficos, mini graficos, formas, etc. De 
Excel. Por otro lado, Power Pivot es diferente, es la unica ficha que 
siempre se debe incluir para extraer... 
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... informacion esencial de Los datos, ademas, su extension a otros 
productos Lo vuelve vital. 

Mas Alla de Excel; Power Bl (.com y Desktop) 

Ahora contamos con otro ambiente para hacer inteligencia de 
negocios de forma amigable, Power Bl esta pensado para llevar a 
cabo el proceso de toma de decisiones en un producto disenado 
100% para ello. 

Power Bl .com es un servicio en la nube para transformar los datos Power Bl (.com) 

de una compania en informacion rica para la toma de decisiones. 

Power Bl Desktop pone a disposicion todas las herramientas Power Bl Desktop 

visuales y demas de Power Bl en el computador. 

En el ambiente de Power Bl tambien contamos con funcionalidades 
para adecuar los datos y visualizarlos, asi como los Power Excel, no 
obstante, lo mas importante a resaltar es que Power Pivot se 
mantiene intacto, todo el lenguaje es exactamente igual, 
exactamente la misma tecnologia. Por lo anterior llamamos la 
esencia, el nucleo a la funcionalidad de Power Pivot extendida a 
otros productos de Microsoft como: Dax Engine. 

Atados con el Dax Engine 

Power Pivot permanece igual, aprenderlo aqui servira para Los 
demas productos de Microsoft centrados en Bl, ademas, con esta 
constante nos podremos mover entre ambientes de forma sencilla 
ya que estan vinculados; atados con el Dax Engine. 
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Beneficios de Power Pivot 


iLIMITACIONES? 

Crear una tabla dinamica 
de la manera clasica con 
respecto a crear una tabla 
dinamica con Power Pivot, 
tiene sus diferencias, 
basicamente porque los 
datos en Power Pivot son 
una base de datos OLAP 
(Ver definicion de OLAP 
en el Anexo A). Para tener 
en cuenta con tablas 
dinamica de Power Pivot: 


Podemos vincular datos de multiples fuentes: Bases de 
datos, data markets, tablas vinculadas, archivos de texto, etc. 


Podemos trabajar con millones de datos de forma eficiente. 


El Lenguaje DAX permite extender la posibilidad de 
nuestros calculos personalizados, cortando todas las 
limitaciones de las tablas dinamicas y convirtiendola en el 
arma letal en nuestro arsenal de Excel. 

El Lenguaje DAX se ha convertido en el nucleo de las 
tecnologias de Business Intelligence de Microsoft. 

Podemos crear diferentes formas de relacionar las tablas de 
datos. 


Los datos de fecha no se 
ordenan 

automaticamente. 


Se pueden ocultar columnas que no queramos ver en el 
panel de campos de las tabas dinamicas. 


Para hacer referencias a 
celdas una tabla dinamica 
con Power Pivot 
solamente se puede hacer 
con el mouse y no con el 
teclado. 

No soportan los campos y 
elementos calculados 
antiguos (En todo caso con 
los calculos DAX no se 
necesitan). 

El Drill Down solo soporta 
1000 registros. 


■ El formato se mantiene constante a lo largo de diferentes 
tablas dinamicas. 

■ Se pueden crear indicadores KPI y jerarquias. 


■ Podemos de manera creativa permitirle al usuario final que 
inserte datos de entrada permitiendo reportes 
parametrizables. 

^Cuando utilizar Power Pivot? 

[Cuando utilizar Power Pivot? La respuesta es sencilla, cada vez que 
tengas que analizar datos, hacer resumes de datos. Para ponerlo de 
forma simple cada vez que tengamos que crear una tabla dinamica 



y queramos ir mas alia en el analisis 
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Descifrando: las Versiones, Ediciones y 
Arquitectura en Power Pivot 

Es importante conocer que versiones de Office contienen Power 
Pivot asi como cuales ediciones lo tienen disponible, de igual 
forma la arquitectura, 32-bits o 64-bits tiene sus pros y contra las 
cuales mencionaremos a continuacion. 

Power Pivot esta disponible para las Versiones de Excel 2010, Versiones 

2013 y 2016. Desafortunadamente si unicamente cuentas con la 
version 2007, es imposible tener acceso a Power Pivot 

Para Excel 2010 se debe descargar el complemento e instalarlo, lo Ediciones Excel 

cual no tiene ninguna limitacion en edicion, es decir, puede ser 
instalado y utilizado en Excel Professional Plus, Home, etc. /" 

TODOS"! 


jToma Nota! 



Para Excel 2010 salieron dos versiones del complemento, llamadas: 
Power Pivot VI y Power Pivot V2. Si el lector esta utilizando Excel 2010 
le recomendamos descargar y utilizar Power Pivot V2, es la version 
mas apropiada para 2010 y la que encajara y coincidira mejor con 
las explicaciones e imagenes de este libro. 


Para Excel 2013, Power Pivot solamente esta disponible para la 
version de Office Professional Plus (Se Activa en complementos 
COM), si tienes Standalone u Office 365 Professional Plus, puede 
ser instalado. 


Ediciones Excel 
2013 
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Ediciones Excel Para Excel en Microsoft Office 2016, Power Pivot esta disponible en 

diferentes ediciones, y para dejar claro cuales la incluyen y cuales 
no, se deja la tabla a continuacion que detalla una y cada una de las 
diferentes ediciones. 




Office 2016 que incluye y no incluyen Power Pivot 


Incluye o No 

Edicion 

-M 

O 

Office 365 Enterprise E2 

cu > 

>s Q_ 

Office 365 Enterprise E3 

U <D 
— £ 

Office Professional Plus 

VJ 

Q_ 

Office Standalone 


Office Home and Business 


Office Home and Student 


Office 365 Home 

S-I 

Office 365 Personal 

u °- 
c L_ 

“ CD 

Office 365 Business Essential 

o 1 

-7 O 

^ Q_ 

Office 365 Business 


Office 365 Business Premium 


Office 365 Enterprise El 


Office 365 University 


jToma Nota! 



Si tienes que manejar cantidades de datos que superan los 10 
millones de registros, es recomendable adquirir el Office con 
arquitectura de 64-bits, esta soporta y ejecuta facilmente cantidades 
superiores, 100 millones de registros los trabaja sin ningun 
inconveniente. 
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<jCual Version Office se Necesita para este Libro? 

Todas Las imageries y expLicaciones de ese Libro son con la interfaz 
de usuario de Power Pivot en Excel 2016 bajo arquitectura de 32- 
bits, no obstante, cada vez que exista una diferencia con Excel 
2013, se hara la nota respectiva, lo cual en algunas ocasiones 
puede aplicar a 2010. Por lo anterior te recomendamos Office 
2013 o 2016 para el desarrollo del presente texto. 

El Siguiente Paso 

Ahora tenemos claro porque ha surgido Power Pivot / El Modelo de 
Datos en Excel y todos los nuevos poderes que nos va a brindar. En 
el siguiente capitulo haremos un breve tour por tablas dinamicas, 
porque de cierta manera eso es Power pivot en Excel: "Tablas 
Dinamicas con esteroides y mas alia", a pesar de ello, si el lector 
tiene un nivel intermedio de tablas dinamicas, puede saltarse el 
capitulo sin ningun inconveniente, de hecho, si es el caso te 
recomendamos fuertemente pasar a conocer la interfaz de Power 
Pivot para Excel en el capitulo tres. 




La Presente Pagina se ha dejado en Blanco de forma deliberada. 




CapituLo 2 


Tablas Dinamicas a la Velocidad de la 

Luz (OpcionalJ 
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NOTA 


Amigo lector, si tu 
conocimiento sobre tablas 
dinamicas es limitado o 
nulo te recomendamos 
que revises el siguiente 
video, que trata en detalle 
los conceptos basicos de 
nuestro llamado 

"Microscopio". 



Fundamentos en Tablas 

Dinamicas 


Fundamentos y Conceptos Basicos 

Para entender adecuadamente el ADN de Power Pivot, primero, 
debemos hacer una parada necesaria en la estacion Tablas 
Dinamicas porque aqui se encuentra la esencia de como trabaja el 
Modelo de Datos, asi que iniciemos por entender que es una Tabla 
Dinamica. 

<jOue es una Tabla Dinamica? 

Sabemos que Microsoft Excel tiene a nuestra disposicion un 
completo arsenal de herramientas para resolver diferentes 
problemas o llevar a cabo una variedad inimaginable de tareas, las 
tablas dinamicas dentro de nuestro arsenal, funcionan como un 
potente microscopio. Supongamos que una base de datos, tabla 
estructurada, o cualquier origen de datos que deseamos analizar es 
una muestra de laboratorio, que a simple vista no proporciona 
ninguna informacion relevante, pero si la observamos a traves de 
nuestro microscopio (un reporte de Tabla Dinamica), se abre la 
posibilidad de entender su composicion, puesto que se puede 
observar en detalle y en diferentes perspectivas que resultan 
interactivas, cada segmento de la muestra, sin modificar su 
estructura, porque el microscopio no modifica la muestra, sino solo 
crea un reflejo o vista de la misma, sin estar conectada 
directamente con ella, al igual que una Tabla Dinamica. 


Definiendo una 
Tabla Dinamica 


Para concluir, una tabla dinamica es una tabla interactiva creada en 
la memoria cache, la cual permite categorizar, organizar, explorar, 
resumir, filtrar, calculary agrupar datos de un origen, para que sean 


presentados a una velocidad y precision sorprendente, lo mas 
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llamativo de las tablas dinamicas es que, con arrastrar, ubicar o 
reorganizar los campos en las diferentes areas de colocacion, se 
cambia la perspectiva del informe, y con ello los totales y valores 
calculados, por eso, su complete dominio es indispensable para 
cualquier persona sin importar su profesion o cargo. 


^Por que utilizar Tablas Dinamicas? 

Son muchos los motivos para utilizar un reporte de tabla dinamica, 
todo depende del escenario en el que nos encontremos, a 
continuacion, puedes ver las razones mas fuertes para 
implementar su uso: 


■ Son una de las formas mas eficientes de calcular, estandarizar Razones para 

y presentar dates. implementar Tablas 

Dinamicas 

■ Su flexibilidad y facil manejo, ayudan a que el usuario cree 
reportes dinamicos con alta capacidad de analisis y 
profundidad en los detalles. 

■ Convierten grandes cantidades de dates en informacion util 
para la toma de decisiones. 

■ Se pueden hacer calculos con diferentes funciones, 
rapidamente. 

■ Agregar totales, subtotales o filtrar, porcategoria requiere poco 
esfuerzo. 

■ Ayudan a detectar relaciones y patrones en los dates. 






Es posible implementar otras caracteristicas de Excel sobre ellas, por 
ejemplo, formato condicional o personalizado, entre otros. 
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Cuando es Inminente utilizar Tablas Dinamicas 

El uso de las tablas dinamicas depende en su gran mayoria del 
contexto en el que nos encontremos y las necesidades que se 
tengan, de ello, depende como podemos abordar el problema y 
solucionarlo con una Tabla Dinamica, por lo general, te 
recomendamos utilizar las tablas dinamicas cuando: 


■ Necesites analizar grandes cantidades de datos. 

■ Debas encontrar tendencias o comportamientos en tus datos. 


■ Ouieras crear un reporte, con un formato adecuado y ayudas 
interactivas, para su posterior distribucion. 

■ Necesites hacer comparaciones entre elementos de una 
categoria, o entre varias categorias. 

■ Requieras agrupar o categorizar datos, o calcular nuevas 
columnas a partir de las que ya se encuentran en la tabla. 


Anatomia de una Tabla Dinamica 


Para aprovechar la flexibilidad de esta herramienta debemos 
explorar su anatomia y saber como esta constituida, el esqueleto 
de una tabla dinamica se compone de cuatro elementos principales 
o areas de colocacion que, en terminos simples, es el lugar donde 
se ubican los campos del origen, para darle forma al reporte: 


Area de Valores 
Area de Filas 
Area de Columnas 
Area de Filtros 
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Es el area de la tabla dinamica donde se realizan los calculos, a 
traves de las diferentes funciones de resumen (mas adelante 
hablaremos de este tema) y por eso, podriamos decir que es el 
alma de una tabla dinamica, siempre se debe ubicar, por lo menos 
un campo y un calculo en esta area. 

Es el area donde se ubica en filas, los campos que posiblemente se 
quieran agrupar o categorizar, si agregamos un campo en esta area, 
en la tabla dinamica aparecen los items en la parte izquierda, 
repetidos una sola vez. 

Es el area donde se visualizan los items de un campo de una tabla 
de origen, como columnas y es ideal para ubicar campos con 
periodos de tiempo, y al igual que el area de filas, los elementos 
no estaran repetidos. 

Esta area es opcional en un reporte, aqui se agregan campos de la 
tabla de origen, para que el reporte filtre informacion dependiendo 
de los items que tenga y asi los calculos de la tabla dinamica se 
actualicen automaticamente, dependiendo de la seleccion. 



Area de 
Valores 


Area de 
Filas 


Area de 
Columnas 


Area de 
Filtros 



Pausemos un Momento 

A los campos del area de filtros se les denominaba campos de pagina, 
de hecho, el area de colocacion tambien se solia llamar de esta 
manera: Area de Paginas. Es bueno saber que hay ciertas 
funcionalidades que aun conservan este antiguo nombre, que es mas 
por compatibilidad con versiones anteriores que por otra cosa. 
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No te preocupes si de entrada parece confusa esta terminologia, 
con el siguiente ejemplo de reporte de tabla dinamica vamos a 
aclarar un poco las ideas. 

A continuacion, se presenta una tabla dinamica que simplemente 
representa los ingresos por pais, en los diferentes anos de una 
compania que distribuye telefonos moviles: 


Producto All 

(— 



Area de Filtros: para este ejemplo, se agrego el campo 
Producto, con ellos podemos seleccionar un Item o elemento 
del campo y automaticamente el reporte se actualiza a este. 




Inpreso ($) Ano 

D 





Paises H2010 

2011 

2012 

2013 

2014 

2015 1 


Argentina $38,160,226 $41,279,866 $45,473,130 $46,820,720 $105,138,582 $56,847,136 

>.464 $41,485,896 $95,235,870 $53,889,658 
1.756 $40,668,002 $90.018.494 $48,935,832 
>.746 $17,013,198 $39,798,130 $22,544,392 
1.188 $34,540,162 $79,454,180 $45,388,760 
.170 $17,033,638 $39,569,502 $23,214,244 



$30,488,076 $33,672,886 $38,252.' 
$31,676,818 $34,032,242 $37,628.' 
$11,761,478 $13,695,764 $15,742/ 
$23,880,880 $27,043,812 $30,792/ 
$11,563,844 $13,397,228 $15,441. 


Area de Filas: aqui se listan una unica vez 
todos los items o elementos del campo Pais. 



Area de 
Columnas: en 

este ejemplo 
se agrego el 
campo Fecha 
a esta area, y 
como puedes 
observar, 
cada 

columna de la 
tabla 
dinamica 
representa un 
item del 
campo fecha, 
es decir los 
anos. 


Area de Valores: aqui se encuentra la suma total de 
los ingresos, este valor cambia dependiendo de los 
campos ubicados en el area de filas o columnas y 
del tipo de funcion de resumen elegida. 


Figura 2. 6- Areas de Colocacion en una Tabla Dinamica 


El reporte de tabla dinamica creado, nos ayuda a analizar la 
situacion relacionada con los ingresos de la compania, ano a ano, 
para cada una de las sedes en los diferentes paises, sin embargo, 
para darle mas interactividad y hacer mas robusto el reporte, 
podemos implementar una funcionalidad de Excel que es muy 
llamativa y a la vez util, hablamos de los Slicer o tambien llamados 




















El ADN DE Power Pivot 



... es exclusiva para tablas dinamicas, se encuentra habilitada para 
ser utiLizada con tablas estructuradas. 

Slicer o Segmentacion de Datos 

Un Slicer es un elemento que funciona igual que un filtro, busca 
dentro de un grupo de datos, un sub grupo que cumpla con una 
caracteristica en particular, y en consecuencia oculta las filas o 
registros que no cumplan con esa condicion y deja a la vista las que 
si, pero con la diferencia que el diseno es llamativo y su manejo es 
mas intuitivo. 


iQue es un 
Slicer? 


Para insertar un Slicer que funcione con un reporte de tabla 
dinamica, debemos dejar la celda activa en algun lugar de la misma, 
nos dirigimos a la pestana ANALIZAR, grupo FILTRAR, y elegimos la 
opcion INSERTAR SEGMENTACION DE DATOS. 


REVISAR VISTA DESARROLLADOR POWERPIVOT 

EQUIPO ANALIZAR 

1^1 Insertar Segmentacion de datos 

Gs fe 

Actualizar Cambiar origen 

T de datos T 

Datos 

Acciones 

Campos, el erne 

yfc Herramientas C 

Relaciones 

Calc 

Insertar escala detiempo 
!jj] Conexiones de filtro 

Filtrar 


Figura 2.7- Insertar Segmentacion de Datos 


En el cuadro de dialogo Insertar Segmentacion de Datos que aparece, 
elegimos el campo de la tabla de origen para la cual vamos a crear el 
Slicer, para este ejemplo, el Nombre del Producto, puesto que debemos 
explorar los ingresos obtenidos ano a ano para cada producto que 
distribuye la compania, por ultimo, presionamos el boton Aceptar. 


Agregar Slicer 


NOTA 


Si quieres profundizar en 
slicers puedes consultar el 
siguiente video, donde 
tambien se estudian los 
slicers de escala de tiempo 
(Time Slicer) y otras cosas 
divertidas con filtros. 



Filtros, Slicers v Escala de 

Tiempo 
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Insertar segmentacion de datos 


mm 


activo todos 

El B Clientes 
El H Pedidos 

E) H ProductosINFO 

□ ID Producto 
0Nombre Producto 

□ Precio (S USD) 


Aceptar Cancelar 


Figura 2.8- Cuadro de Dialogo Insertor Segmentation de Datos 


NOTA 

Podemos modificar la 
forma, color o cualquier 
caracteristica que viene 
por defecto con el Slicer, 
ademas, existen dos 
categorfas de Slicer, el que 
ya conocemos, y la Escala 
de Tiempo, en el video 
que ya te hemos 
recomendado, se 

encuentran a profundidad 
estas tematicas. 


Automaticamente aparece nuestro Slicer; como ya lo hemos 
repetido, su diseno es bastante atractivo y si se quiere podemos 
personalizarlo aun mas. 



Figura 2.9- Slicer o Segmentation de Datos 
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El funcionamiento de un slicer es muy simple, cada boton que 
contiene es un item o elemento, con lo cual podemos filtrar la tabla 
dinamica, por ejemplo, si presionamos el boton Alcatel One con clic 
izquierdo sobre el, la tabla recalculara los valores para que muestre 
la informacion referente a este producto. 


Producto 





' * j 

Alcatel One 

Galaxy SI 

Galaxy S2 

Galaxy S3 

Galaxy S4 

a 

Galaxy S5 

Galaxy S6 

Iphone 2 

Iphone 3 

Iphone 4 

V 


Ingreso ($) Ano 

B 





Paises H2010 

2011 

2012 

2013 

2014 

2015 


Argentina $1,635,200 $1,750,000 $1,974,000 $1,915,200 $4,323,200 $2,440,200 

Chile $1.339.BOO $1,359,400 $1,612,300 $1,310,200 $3,879,400 $2,332,400 

Colombia $1,331,400 $1,355,200 $1,570,800 $1,689,800 $3,784,200 $1,999,200 

Ecuador $467,600 $575,400 $655,200 $730,800 $1,635,200 $893,200 

Peru $1,009,400 $1,086,400 $1,290,800 $1,589,000 $3,339,000 $1,902,600 

Uruguay $541,800 $616,000 $674,800 $719,600 $1,647,800 $954,800 

Figura 2.10- Botones de un Slicer 


Funcionamiento 


Este boton nos permite 
eliminar todos los filtros 
existentes, e 

implicitamente nos 

indica que hay un filtro 
aplicado. 


Los botones en bianco, 
senalan que el item no 
ha sido elegido para 
filtrar, por el contrario, 
del boton Alcatel One, 
que se encuentra 
resaltado. 


Para seleccionar varios items en el slicer, basta con dar clic sobre 
cada boton mientras tenemos presionada la tecla Ctrl, esto es asi 
en las versiones de Excel 2010 y 2013, para Excel 2016 tenemos 
una alternativa adicional, la opcion Seleccion de Multiples 
Elementos que se encuentra en la parte superior derecha. 


Seleccion 
Multiple Excel 
2016 



r ’ 

m 

— . 

% 

TV'ilAJM L J fl fcfl 

i_ j 

A 

1 UWNHUIV1L 

>e eccion multiple lAlt+S) 



Figura 2.11- Boton para Seleccionar Multiples elementos de un Slicer 


Ya hablamos un poco sobre slicers, y ahora que entendemos su 
fuerte relacion con las tablas dinamicas, recordemos como se crea 
un reporte. 
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Tablas Dinamicas a la Velocidad de la Luz 


Creadon de una Tabla Dinamica 

Como hemos hablado a lo Largo del capitulo, crear una tabla 
dinamica requiere muy poco esfuerzo, solo basta con hacer un par 
de clics y la tarea se lleva acabo, todo gracias a que existen dos 
caminos para construirlas, asi que demos un vistazo a cada uno de 
ellos. 


Tablas Dinamicas 
Recomendadas 


Primero, vamos a situar La celda activa sobre la base de datos o tabla 
estrudurada si se encuentra en Excel, luego, en La pestana Insertar, 
vamos al grupo Tablas y alii damos clic en el comando Tablas 
Dinamicas Recomendadas, en el cuadro de dialogo Tablas Dinamicas 
Recomendadas, aparecen varias sugerencias de como queremos 
que sea creada la tabla dinamica, es decir, nos hace varias 
sugerencias sobre la composicion de la tabla o mejor, que campos 
deben estar ubicados en las areas de colocacion. 


Comando 

Tablas 

Dinamicas 

Recomendadas. 


Este es el listado de sugerencias, 
se muestran diferentes 
posibilidades de configuracion 
para el reporte (La configuracion 
de una tabia dinamica se refiere a 
la organization que tienen los 
campos en las areas de 
colocacion), si una de estas se 
ajusta a lo que deseamos de 
entrada, solo debemos 
seleccionarla y presionar el boton 
Aceptar, el reporte sera creado 
automaticamente. 


i ■ B 



DISENO DE PAGINA 

"o $ 


FORMULAS DATOS REV 


.□ L# 

Imageries Imageries 

en li'nea A+ 


41 Tienda 


□ || 


Mis aplicaciones 0 

recomei 

? X 


* Suma de Ingreso ($) por ID de Cliente 

La vista previa se ha generado basandose en una 
muestra de los datos de origen y puede no coincidir 
con el resultado final. 

Etiquetas de fila T Suma de Ingreso ($) 


111225 
111249 
141223 
161217 
161229 
171219 
171251 
181215 
181241 
181253 
191221 
Total general 


Cambiar datos de oriaen... 


46812746 

46812582 

29884020 

38065470 

38757070 

29569306 

29957498 

25247416 

25444530 

25134516 

28885708 

364570862 


Aceptar 


mmmm- 

mmmmd 


Figura 2.12 - Tablas Dinamicas Recomendadas 
































El ADN DE Power Pivot 


Este metodo es el mas comun y utilizado por los usuarios de Creadon 

nuestra hoja de calculo para crear tablas dinamicas, primero, Manual 

selecdonamos los datos de origen, posteriormente, en la pestana 

Insertar, grupo Tablas, damos clic sobre el comando Tabla Dinamica 

y automaticamente aparece el cuadro de dialogo Crear Tabla 

Dinamica. 


Creartabla dinamica 

Seleccione los datos que desea analizar 
® Seleccione una tabla o rango 
Tabla o rango: 

O Utilice una fuente de datos externa 


Nombre de conexion: 

O Usar el modelo de datos de este libro 


Elija donde desea colocar el informe de tabla dinamica 


® Nueva hoja de calculo 
O Hoja de calculo existente 
Ubicacion: 


Elige si quieres analizar varias tablas 
I I Agregar estos datos al Modelo de datos 



X 



La opcion Utilice una fuente de datos 
externa, permite crear la tabla 
dinamica con un origen de datos que 
no este en el libro actual, por ejemplo, 
otro libro, una base de datos en 
Access, en SQL Server entre otros. 


m 


Cancelar 


Esta opcion es nueva en Excel 2016, nos 
permite crear una tabla dinamica 
utilizando el modelo de datos actual (eso 
cobrara mas sentido a medida que avance 
en el libro). 


\ 


Estas opciones permiten seleccionar el 
lugar donde se ubicara la tabla dinamica, 
ya sea en una hoja nueva o en una 
existente en una celda determinada. 


Habilitando esta opcion, podemos agregar al modelo de datos la tabla de 
origen, posteriormente relacionar para luego crear la tabla dinamica. 


Figura 2.13 - Cuadro de Dialogo Crear Tabla Dinamica 


En dicho cuadro de dialogo definimos los datos de origen para 
crear el reporte, para este ejemplo, la tabla Pedidos que esta 
alojada en el mismo libro, con la tabla elegida, solo falta dar clic en 
Aceptar, y en una nueva hoja se genera el area para la tabla 
dinamica, ahora, vamos a situar los diferentes campos en las areas 
de colocacion. 


NOTA 

Recuerda que los datos 
deben estar adecuados, es 
decir, no debe haber filas 
ni columnas vadas, las 
columnas deben tener 
etiquetas definidas, no 
tienen que existir totales ni 
subtotales y, por ultimo, 
recuerda que solo deben 
existir las etiquetas de 
cabecera de las columnas. 
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Tabla dinamicaZ 


Para generar un informe, elija los 
Campos de la lista de campos de la 
tabla dinamica 



Figura 2.14 - Espocio para Generar Informe 


Cuando ubicamos La celda activa dentro del area de creacion del 
reporte, aparece el Panel de Campos (el lugar donde la magia 
ocurre), aqui arrastramos los campos a las diferentes areas de 
colocacion. 


Campos de tabla dinami... T x 

ACTIVO TODOS 



Seleccionar campos para agregar al 
informe: 


o - 


a ^ Pedidos 

l~~l Codigo Pedido 

HU Fecha 
0 Fecha (ano] 
l~~l Fecha [mes] 

Fecha ftrimestrel 

Arrastrar campos entre las areas siguientes: 


- 


T FILTROS 

nil COLUMNAS 

Producto T 

Fecha [ano] T 



= FI LAS 

£ VALORES 

Pais T 

Ingreso (S) T 

l~~l Aplazar actualiiacion 

del dis... ACTUALIZAR 



Figura 2.15 - Panel de Campos 







































El ADN DE Power Pivot 



En el panel de campos, ubicamos el campo Producto en el area de 
Filtros, Fecha en el area de columnas, Pais en el area de filas y por 
ultimo Ingreso en el area de valores y el resultado es la tabla 
dinamica que hemos visto en el transcurso del presente capitulo. 

Producto All E 


Ingreso ($) Ano 

□ 





Paises ^2010 

2011 

2012 

2013 

2014 

2015 


Argentina 

Chile 

Colombia 

Ecuador 

Peru 

Uruguay 


$38,160,226 

$30,488,076 

$31,676,818 

$11,761,478 

$23,880,880 

$11,563,844 


$41,279,866 

$33,672,886 

$34,032,242 

$13,695,764 

$27,043,812 

$13,397,228 


$45,473,130 

$38,252,464 

$37,628,756 

$15,742,746 

$30,792,188 

$15,441,170 


$46,820,720 
$41,485,896 
$40,668,002 
$17,013,198 
$34.540.162 
$17,033,638 


$105,138,582 
$95,235,870 
$90,018,494 
$39,798,130 
$79.454.180 
$39,569,502 


$56,847,136 

$53,889,658 

$48,935,832 

$22,544,392 

$45,388,760 

$23,214,244 


Figura 2.16 - Tabla Dinamica de Ingresos 


NOTA 

Para agregar los campos 
en las diferentes areas de 
colocacion, basta con 
elegir un campo, 
seleccionarlo con clic 
izquierdo y 

manteniendolo 
presionado, lo 

arrastramos al area de 
colocacion de nuestra 
preferencia, muy simple 
<mo te parece? 


Amigo lector, queremos decirte que esta tabla dinamica no ha sido 
creada solamente a partir de la tabla de origen Pedidos, la verdad 
se ha construido con la ayuda de varias tablas que han sido 
relacionadas, a traves del modelo de datos, pero no te preocupes 
en el Capitulo 5, conoceras como realizar este maravilloso 
procedimiento, por ahora vamos a hablar de los diferentes calculos 
que tenemos a disposicion para analizar datos con esta 
herramienta. 


Calculos en Tablas Dinamicas 

Al crear un reporte de tabla dinamica se nos abre un abanico de 
posibilidades para hacer calculos, en su momento eran apropiados 
y suficientes para explorar informacion, pero con la llegada del "Big 
Data" se complied el asunto porque salieron a relucir graves 
limitaciones que tienen las tablas dinamicas en este ambito, sin 
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NOTA 

T ristemente contamos con 
once funciones de 
resumen, una cifra muy 
limitada para la cantidad 
de calculos que podemos 
llegar a necesitar, sin 
embargo, como ya lo 
hemos mencionado 
Power Pivot es la 
respuesta. 


NOTA 


Estimado lector, puedes 
profundizar en las 
funciones de resumen en 
el siguiente enlace 



Funciones de Resumen 


... ha Uegado al rescate, en Los capitulos posteriores todo tomara 
sentido, por el momento, hablemos de Los calculos que se pueden 
hacer con tablas dinamicas 

Funciones de Resumen 

Las funciones de resumen son los tipos de calculos que podemos 
hacer en el area de valores de una tabla dinamica, son realmente 
utiles y nos ayudan a entender el comportamiento de nuestros 
datos, a continuacion, se muestran nuestras las once funciones: 



Listado de Funciones de Resumen 


Funcion 

Description 

Suma 

Suma todos los valores existentes en 
el campo, es decir, calcula un total 

Cuenta 

Cuenta el numero de datos o celdas 
que tiene el campo 

Promedio 

Encuentra el promedio del campo 

Max. 

Muestra el valor maximo del campo 

Min. 

Muestra el valor mlnimo del campo 

Producto 

Multiplica entre si, todos los valores 
del campo 

Contar 

Cuenta los datos o celdas de tipo 

Numeros 

numerico que tiene el campo 

Desvest 

Encuentra la desviacion estandar 
muestral del campo 

Desvestp 

Encuentra la desviacion estandar 
poblacional 

Var 

Calcula la varianza de una muestra 

Varp 

Calcula la varianza poblacional 


Despues de insertar o cambiar una funcion de resumen, podemos 


modificar la forma en que los datos son visualizados... 
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Tipos de Visualizacion de Valores 


Los tipos de visualizacion de valores son el modo o forma en que 
los datos se ven en el area de valores de una tabla dinamica, a 
continuacion, se listan: 



Listado de Tipos de Visualizacion de Valores 


Visualizacion 

Description 


Muestra cada dato del area de valores como un 

% del Total General 

porcentaje, teniendo en cuenta que el total general es 
100% 

% del Total de 
Columnas 

Visualiza cada dato del area de valores como un 

porcentaje, teniendo en cuenta que el total de la 
columna es el 100% 


Muestra cada dato del area de valores como un 

% del Total de Filas 

porcentaje, teniendo en cuenta que el total de la fila 
es el 100%> 

% de 

Representa los valores en porcentaje respecto a un 
Item o sub categorla elegida 

% de Total de Filas 

Muestra cada dato del area de valores como un 

Principales 

porcentaje de la suma general de la fila principal 

% de Total de 
Columnas Principales 

Muestra cada dato del area de valores como un 

porcentaje de la suma general de la columna 
principal 

% del Total Principal 
General 

Muestra los datos del area de valores, como un 
porcentaje respecto al gran total de toda la tabla 
dinamica 

Diferencia de 

Muestra la diferencia de un item comparado con 
otro item 

% de la Diferencia de 

Muestra como porcentaje la diferencia de un item 
respecto a otro 

Total en 

Calcula un total acumulado 

% del Total en 

Calcula un total acumulado como porcentaje del 

Total 

Clasifica r de Menor a 

Clasifica los valores con numeros enteres 

Mayor 

consecutivos donde el 1 es el valor mas pequeno 

Clasificacion de 

Clasifica los valores con numeros enteres 

Mayor a Menor 

consecutivos donde el 1 es el valor mas grande 

indice 

Calculo la importancia de un valor respecto al 
conjunto total de valores en el reporte 


NOTA 


iQuieres profundizar en 
cada uno de estos tipos de 
visualizacion de valores?, 
pues bien, mi amigo, 
jtenemos el video! Es una 
mini serie de tres videos 
donde se explora cada 
una de las posibilidades, 
explicando su teoria e 
implicaciones detras, 
donde ademas se van 
plasmando todo con 
ejemplos concretos. 


iDISFRUTALO! 



Tipos de Visaulizacion de 

Valores 
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Campos y Elementos Calculados 

Es muy comun que al crear un reporte debamos expandir la 
exploracion de datos y hacer analisis con informacion que no se 
encuentra en los datos de origen, pero si en la tabla dinamica, en 
consecuencia, existen las columnas y elementos calculados, asi 
que demos un vistazo: 

Campos Son columnas "virtuaies "creadas a partir de operaciones realizadas 

Calculados entre las mismas columnas de la tabla dinamica, decimos que son 

virtuaies por que no existen en el origen de datos. Al crear un 
campo calculado contamos con el beneficio que se puede 
interactuar con el al igual que un campo comun. 

Para entender los campos calculados, detengamonos un momento 
en el siguiente reporte de tabla dinamica que contiene los ingresos 
y costos de una compama que cuenta con distintas sucursales en 
varios paises, en consecuencia, iQue debemos hacer para 
encontrar el costo total de funcionamiento?, bueno creo que ya lo 
sabes, sumar los costos variables con los costos totales, asi que 
vamos a la accion. 



Isucursal 

Q Ingresos ($) 

Costos Fijos ($) 

Costos Variables ($)| 

Argentina 

446.349 

171.331 

90.731 

Bolivia 

454.011 

164.527 

95.634 

Brasil 

429.630 

170.016 

34.199 

Chile 

453.710 

163.101 

36.635 

Colombia 

419.066 

131.344 

39.413 

Ecuador 

412.72S 

162.753 

34.231 

Peru 

466.69S 

171.709 

39.665 

Uruguay 

423.440 

177.920 

94.459 

Total general 

3.506.132 

1.368.251 

71 5.067 



Figura 2.17 - Reporte de Tabla Dinamica 






El ADN DE Power Pivot 



Para insertar el campo calculado Costos Totales, con la celda activa 
sobre la tabla dinamica, vamos a la pestana Analizar, grupo 
Calculos, y en el comando Campos, Elementos y Conjuntos, 
seleccionamos la opcion Campo Calculado, en el cuadro de dialogo 
Insertar Campo Calculado que aparece, vamos a sumar el campo 
Costos Fijos con los Costos Variables como se muestra a 
continuacion. 



Figura 2.18- Creor Campo Calculado 


jToma Nota! 



El motor de formulas para campos y elementos calculados “clasico" 
es completamente independiente de las funciones que manejamos 
dta a dta en Excel. Esta es una de las razones porque estan restrlctlvo 
lo que podemos hacer con ellas y porque Microsoft ha invertido 
practicamente $0 USD en presupuesto para su mejora en los 16 ahos. 
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NOTA 


Si quieres estudiar toda la 
tematica asociada a 
campos calculados, 
puedes hacerlo en el 
siguiente video. 



Campos v Elementos 

Calculados 


Una vez creada La formula en el cuadro de dialogo, presionamos el 
boton Aceptar y obtenemos los costos totales por sucursal. 


1 Sucursal 

H Inqresos ($) 

Costos Fijos ($) Costos Van 

ables ($) 

Suma de Costos Totales 1 

Argentina 

446.849 

171.331 

90.781 

262.662 

Bolivia 

454.011 

164.527 

95.634 

260.161 

Brasil 

429.630 

170.016 

34.199 

254.215 

Chile 

453.710 

163.101 

36.635 

254.736 

Colombia 

419.066 

131.344 

39.413 

270.757 

Ecuador 

412.72S 

162.753 

34.231 

246.934 

Peru 

466.69S 

171.709 

39.665 

261.374 

Uruguay 

423.440 

177.920 

94.459 

272.379 


Total general 3.506.132 1.368.251 715.067 2.083.318 


Campo Calculado 


Figura 2.19- Campo Calculado de Costos Totales 



Pausemos un Momento 

Algo interesante de las columnas y elementos calculados claslcos de 
tablas dinamicas, es la referenciacion por posicion, aunque tiene 
muchas limitaciones era una buena alternativa para determinar la 
media mov'd, no obstante, aqu( lo mencionamos como una 
curiosidad. Pues con Power Pivot esto ya no necesario. 



jToma Nota! 


En campos calculados puedes hacer las siguientes operaciones: 
Suma (+), Resta (-), Multiplicacion (*), Division (/), Porcentaje (%), y 
Potenciacion (*). 


Es cierto que los campos calculados resultan muy utiles para 
expandir el analisis de datos en una tabla dinamica, sin embargo, 
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■ No puedes utilizar referencias a celdas ni nombres definidos o 
elementos que se encuentren fuera de la tabla dinamica, para 
crear campos calculados, es como estar en una isla, solo 
puedes utilizar lo que esta en ella, puesto que el campo 
calculado se crea en la memoria cache. 

■ La cantidad de operaciones disponibles, que se pueden 
realizar es muy limitada, y probablemente no sean suficientes 
para obtener informacion util. 

■ Es posible utilizar constantes en los calculos, asi no resulte 
muy eficiente. 

■ En la formula del campo calculado, no puedes hacer referencia 
a totales o sub totales de la tabla dinamica. 


Son elementos virtuales, calculados a partir de operaciones entre Elementos 

items pertenecientes a los campos de la tabla dinamica, si los Calculados 

campos calculados los visualizamos como una columna nueva en 
el reporte, podemos decir que un elemento calculado es un item o 
"celda nueva" dentro de un campo existente en la tabla dinamica, 
y se manifiesta como una nueva fila. 


Son muy utiles debido a que nos permiten agrupar o resumir 
elementos que ya se encuentran en la tabla por categories o 
simplemente hacer operaciones entre ellos para obtener un total, 
bueno, ha llegado la hora de la verdad, construyamos un elemento 
calculado, por eso, supongamos que debemos encontrar el 
promedio de los ingresos obtenidos en Argentina, Bolivia, Brasil y 
Chile, porque representan una zona de ventas importante. 
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Con la celda activa situada en un elemento de cualquier campo 
diferente al area de valores, nos dirigimos a la pestana Analizar, 
grupo Calculos, damos clic en el comando Campos, Elementos y 
Conjuntos, y alii seleccionamos Elementos Calculados, para 
construir la formula en el cuadro de dialogo Insertar Elemento 
Calculado. 



Figura 2. 20 - Insertor Elementos Calculados 


Al finalizar la construccion de la formula, presionamos el boton 
Aceptar y obtenemos la nueva fila en la tabla dinamica. 


Sucursal 

Q Inqresos (S) 

Costos Fijos (S) Costos Variables ($) Suma de Costos Totales 1 

Argentina 

446.849 

171.881 

90.731 

262.662 

Bolivia 

454.011 

164.527 

95.634 

260.161 

Brasil 

429.630 

170.016 

34.199 

254.215 

Chile 

453.710 

163.101 

36.635 

254.736 

Colombia 

419.066 

131.344 

39.413 

270.757 

Ecuador 

412.728 

162.753 

34.231 

246.934 

Peril 

466.698 

171.709 

39.665 

261.374 

Uruguay 

423.440 

177.920 

94.459 

272.379 

Promedio (Zona 1) 446.050 

163.631 

39.325 

257.956] 

Total general 

3.952.182 

1.536.882 

804.392 

2.341.274 



Figura 2. 21 - Elemento Calculado en la Tabla Dinamica 
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Adicional a las limitaciones descritas para campos calculados que 
tambien aplican en elementos calculados, se suman: 


■ No puedes usar elementos calculados cuando la tabla 
dinamica se ha creado con promedio, varianza o desviacion 
estandar. 

■ No puedes utilizar un campo de pagina para crear un campo 
calculado. 

■ No es posible ubicar el campo calculado en el area de filtros. 


■ No se puede anadir un campo calculado a un reporte de tabla 
dinamica que tiene campos agrupados 

■ En la creacion de la formula, no se puede hacer referenda a 
items de otros campos diferentes, a con los que se esta 
trabajando. 

Ahora que sabemos los beneficios de los campos y elementos 
calculados, ademas de sus limitaciones, vamos a hablar delformato 
de una tabla dinamica, no olvidemos que una buena apariencia 
facilita la lectura por parte del usuario final. 


Formato de una Tabla dinamica 


Cuando creamos una tabla dinamica el diseno que viene por 
defecto, deja bastante que desear, por eso optimizar ciertos 
elementos que la componen. Asi que Empecemos nuestro 
recorrido, porque de ello depende que el usuario final entienda la 
informacion que transmite el reporte, a continuacion, te mostramos 
como se ve una tabla dinamica recien creada. 
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NOTA 


Etiquetas de fila T Suma de lngresos($) Suma de Costas Fijos(S) Suma de Costos Variables($) 


Argentina 

446S4S 

171881 

30781 

Bolivia 

454011 

164527 

35634 

Brasil 

423630 

170016 

84133 

Chile 

453710 

168101 

86685 

Colombia 

413066 

181344 

83413 

Ecuador 

412728 

162753 

84231 

Peru 

466638 

171703 

83665 

Uruguay 

423440 

177320 

34453 

Total general 

3506132 

1368251 

715067 


Para profundizar en el 
Formato de una Tabla 
Dinamica puedes ver el 
siguiente video: 



Formato de una Tabla 

Dinamica 


Figura 2.22 - Diseno por defecto de una Tabla Dinamica 

Diseno 

Las tablas dinamicas que se han tratado durante este capitulo 
tienen un estilo predisenado denominado Estilo de Tabla Dinamica 
Medio 4, uno de los ochenta y tres estilos que proporciona Excel. 
Para elegir alguno, situamos la celda activa sobre la tabla dinamica, 
en la pestana DISENO, grupo Estilos de Tabla Dinamica, 
desplegamos la lista que aparece y seleccionamos el que sea de 
nuestra preferencia dando clic izquierdo sobre el. 


En esta 

opcion 

podemos 

crear 

nuestros 

propios 

estilos de 

tabla 

dinamica 

J 


fiB 


ilpy 



|| 




jut] Nuevo estilo detabla dinamica,,. 
Borrar 


Figura 2.23 - Estilos Predisehados de Tabla Dinamica 
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Modificar Formato en el Area de Valores 

Para mostrar correctamente los valores que aparecen en la tabla 
dinamica debemos agregar un formato de acuerdo a su naturaleza, 
para cambiar el formato de numero, seleccionamos toda el area de 
valores y damos clic derecho sobre la tabla dinamica, elegimos la 
opcion Formato de Numero, y en el cuadro de dialogo Formato de 
Celdas seleccionamos la categoria dependiendo de los datos, para 
este caso, la categoria Numero con cero numeros decimales. 



Figura 2.24 - Formato en el Area de valores 


Al finalizar la seleccion de formato presionamos el boton Aceptar 
y los cambios se ven reflejados en el Area de valores. 
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Etiquetas 

Cuando creamos una tabla dinamica, aparecen con ella, una serie 
de etiquetas que no resultan claras, para cambiarlas solo basta con 
situar la celda activa sobre alguna de las etiquetas que vamos a 
modificar, y en la barra de formulas la renombramos, este 
procedimiento se debe repetir para cada etiqueta. 



A nniiri'i C Q fli U ”711 OOI 


Figura 2. 25 - Modificar Etiquetas 


Totales Generates 

Dependiendo de que informacion necesitamos mostrar en el 
reporte se pueden mostrar o no, los totales generates, tanto de filas 
como columnas, o ambas si es el caso, para ello, vamos a la pestana 
Diseno, grupo Disefio, y en el comando Totales Generates, 
seleccionamos la opcion Activado solo para Columnas. 


;== 0 Encabeza 

Totales Diseno de Filas en 0 Encabeza 


generales T informer bianco”' 


ill 

Desactivado para filas y columnas 

iiiiiiiiiii 

. 

Activado para filas y columnas 

■ 1111ii111 

. 

Activado solo para filas 

ill 

Activado solo para columnas 




Figura 2.26- 0 pci ones para Totales Generates 
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Dile No a las Celdas Vacias 


Cuando creamos una tabla dinamica pueden aparecer en el campo 

de valores, celdas en bianco, implicitamente sabemos que el valor NOTA 


es cero, sin embargo, NO es una buena practica dejar estos campos 
asi, en su lugar, podemos sustituirlo con el numero cero, para llevar 
a cabo esta accion, damos clic derecho sobre la tabla dinamica, y 
damos clic en Opdones de Tabla Dinamica, en este cuadro de 
dialogo, nos dirigimos a la pestana Diseno y Formato, aqui 
habilitamos la opcion Para Celdas Vacias, Mostrar: y escribimos en 
el cuadro de texto el numero 0, para finalizar damos clic en Aceptar 



Si tienes muchas filas en tu 
tabla dinamica y quieres 
facilitar la lectura, puedes 
agregar bandas al diseno, 
situando la celda activa 
sobre el reporte, vamos a 
al grupo Opciones de 
estilo de tabla dinamica 
que se encuentra en la 
pestana Diseno, y alii 
habilitamos la opcion Filas 
Con Bandas. 


Opcion, Para 
Celdas Vacias, 
Mostrar: 


Figura 2.27 - Cuadro de Dialogo Opciones de Tabla dinamica 


Bueno, ya sabemos como hacer rapidamente algunos cambios 
cosmeticos en nuestros reportes, pero que pasa si la estructura que 
tenemos no es la ideal, afortunadamente, contamos con la opcion 
Diseno de Informe. 
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Diseno de Informe 

Existen varias opciones para modificar La estructura de nuestra 
tabla dinamica, como Lo hemos mencionado durante todo eL 
capftulo, debemos elegir La opcion mas adecuada dependiendo deL 
objetivo que tiene el reporte. Para cambiar eL diseno situamos La 
celda activa sobre la tabla dinamica, y en el grupo Diseno 
desplegamos las opciones del comando Diseno de Informe para 
elegir alguna de las tres posibilidades. 


0 Encabezados defila f 


Diseno de Filas en 0 Encabezados de columna □< 
informed bianco^ 


3 


Mostrar en forma com pa eta 
Mostrar en forma de esquema 

Mostrar en formato tabular 

Repetir t o das las etiquetas de elementos 
No repetir las etiquietas de elementos 


ji ji ■ J ' .i r_ 


i ■ j I I ^ 


Figura 2.29- Opciones en Diseno de Reportes 


Mostrar en Esta es La estructura por defecto que asigna Excel al crear la tabla y 

Khhj ompacta esencia agrupa todos los items situados en el campo fila 

dependiendo de las categories que existan, es ideal para ahorrar 
campo en la hoja de calculo y ser detallado en la presentacion de 
los datos. 



























El ADN DE Power Pivot 



ISueursal P Ingresos ($) 

Costos Fijos ($) Costos Variables ($) 

Suma de Costos Totales 1 

□ 

Argentina 

44.669 

12.577 

7.204 

19.731 

Bolivia 

44.226 

13,327 

6.969 

20.296 

Brasil 

25.639 

11.357 

7.040 

18.397 

Chile 

38.452 

16.299 

7.223 

23,527 

Colombia 

25.133 

17.073 

8.335 

25.453 

Ecuador 

49.S3S 

11.969 

7.250 

19.219 

Peru 

43.179 

17.673 

9.034 

26.762 

Uruguay 

33.295 

14.673 

6.265 

20.943 

□ 

Argentina 

40.950 

16.133 

9.465 

25.653 

Bolivia 

43.929 

15.352 

5.059 

20.411 

Brasil 

37.439 

10.733 

7.425 

13.153 

Chile 

30.713 

15.072 

7.720 

22.792 

Colombia 

32.660 

14.234 

3.707 

22.941 

Ecuador 

37.446 

16.992 

6.313 

23,305 

Peru 

39.137 

17.337 

7.164 

25.001 

Uruguay 

33.623 

13.565 

9.269 

22.334 


- 


Figura 2.30 - Mostrar en Forma Compacta 


Este tipo de estructura, asigna una columna individual para cada Mostrar en Forma 

campo que ha sigo agregado en el area de filas, es inusual utilizar de Esquema 

este diseno, sin embargo, en algun momento puedes recurrir a el. 


Mes P Zona P Ingresos ($) Costos Fijos ($) Costos Variables ($) Suma de Costos Totales 


Argentina 

44.669 

12.577 

7.204 

19.781 

Bolivia 

44.226 

13.327 

6.969 

20.296 

Brasil 

25.639 

11.857 

7.040 

18.897 

Chile 

38.452 

16.299 

7.228 

23.527 

Colombia 

25.133 

17.073 

8.385 

25.458 

Ecuador 

49.838 

11.969 

7.250 

19.219 

Peru 

43.179 

17.678 

9.084 

26.762 

Uruguay 

33.295 

14.678 

6.265 

20.943 

0 

Argentina 

40.950 

16.188 

9.465 

25.653 

Bolivia 

48.929 

15.352 

5.059 

20.411 

Brasil 

37.489 

10.733 

7.425 

18.158 

Chile 

30.713 

15.072 

7.720 

22.792 

Colombia 

32.660 

14.234 

8.707 

22.941 

Ecuador 

37.446 

16.992 

6.313 

23.305 

Peru 

39.137 

17.837 

7.164 

25.001 

Uruguay 

38.628 

13.565 

9.269 

22.834 


0 


NOTA 

Para rellenar los campos 
correspondientes con la 
etiqueta del Item y no 
dejar la columna vacia 
como en la imagen 
puedes habilitar la opcion 
RepetirTodas las Etiquetas 
de Elementos que aparece 
en el comando Diseno de 
Informe. 


Figura 2.31- Mostrar en Forma de Esquema 
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Mostrar en 
Formato Tabular 


La estructura tabular asigna una columna individual para cada 
campo agregado en el area de filas y ademas calcula subtotales 
para cada una de las categories o grupos generados. 


Mes 

*3 Zona B Ingresos ($) 

Costos Fijos ($) Costos Variables ($) 

Suma de Costos Totales 

eJ - j 

Argentina 

44.669 

12.577 

7.204 

19.731 


Bolivia 

44.226 

13.327 

6.969 

20.296 


Brasil 

25.639 

11.357 

7.040 

18.897 


Chile 

38.452 

16.299 

7.223 

23.527 


Colombia 

25.133 

17.073 

3.335 

25.453 


Ecuador 

49.838 

11 .969 

7.250 

19.219 


Per Q 

43.179 

17.673 

9.034 

26.762 


Uruguay 

33.295 

14.673 

6.265 

20.943 


TO 

Argentina 

40.950 

1 6.1 S3 

9.465 

25.653 


Bolivia 

43.929 

15.352 

5.059 

20.411 


Brasil 

37.439 

10.733 

7.425 

13.153 


Chile 

30.713 

15.072 

7.720 

22.792 


Colombia 

32.660 

14.234 

3.707 

22.941 


Ecuador 

37.446 

1 6.992 

6.313 

23,305 


Pert 

39.137 

17.337 

7.164 

25.001 


Uruguay 

33.623 

13,565 

9.269 

22.334 


Figura 2 .33 - Mostrar en Formato Tabular 


Aunque todo lo que hemos visto durante este capitulo sobre tablas 
dinamicas puede parecer sorprendente, debemos hablar 
nuevamente, de algo que no podemos olvidar, y son las debilidades 
que nuestro "Microscopic/' tiene. Si lo sabemos, es triste... 


Repasando: Limitaciones de un Reporte de Tabla 
Dinamica 


■ Duplicar el formato del area de valores en otra tabla dinamica 
no es posible, se debe repetir el proceso nuevamente. 


■ Incapacidad para relacionar varias tablas y crear un reporte de 
tabla dinamica, una falencia muy sensible por que limita la 
flexibilidad del analisis y la productividad del usuario. 
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■ Las funciones de resumen y Los tipos de visualizacion de valores no 
ofrecen un abanico de posibilidades muy amplio para hacer 
calculos. 

■ Con mas de cien mil registros el reporte de tabla dinamica pierde 
eficiencia porque su tiempo de respuesta es lento. 

■ Los campos y elementos calculados terminan encerrandonos en una 
jauLa, porque no podemos tomar recursos que esten por fuera de La 
tabla dinamica. No se puede hacer referencias z totales genereles ni 
subtotales. 

■ Limitacion para recibir datos por parte del usuario. 

■ No es posible crear atajos o agrupaciones para campos calculados 
que guardan una estructurada intimamente relacionada y que 
generalmente se utilizan como un todo y no por separado. 


Aunque ya hemos hablado de esto en el capitulo uno, queremos 
recordarte que no todo esta perdido y que ha llegado al rescate Power 
Pivot, pero era necesario hablar de tablas dinamicas, porque asi, 
entenderas mejorelfuncionamientoy potencialdelADN de Power Pivot, 
iniciemos nuestro viaje a este nuevo mundo lleno de posibilidades. 



Pausemos un Momento 

Como hablamos en el capttulo l, no significa que las tablas dinamicas 
“clasicas" no sirven en gran medida, en realidad es la funcionalidad 
mas poderosa en Excel, sin embargo, el big data y la inteligencia de 
negocios ha resaltado estas falencias por lo que ha tenido que 
evolucionar. 
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Figura 2 .34 - El Molesto IMPORTARDATOSDINAMICOS 


NOTA 

Las formulas cubos son 
fades de entender e 
implementar, una vez 
hayas avanzado en este 
libro mas alia del capftulo 
8, te recomendamos que 
busques loa artfculos obre 
formulas cubos. 


Algo adicional que queremos mencionar es la funcionalidad de 
IMPORTARDATOSDINAMICAS, aquellas funciones que nos permite 
obtener datos de una tabla dinamica a ellas normales de Excel tal 
manera que se actualice junto al reporte 

Esta funcionalidad era y sigue siendo para algunos, el causante de 
muchos dolores de cabeza, ya que su utilizacion generar algunos 
inconvenientes en tablas dinamicas, no queremos discutir esto 
aqui pues con Power Pivot disponemos de formulas cubos. 


Recursos y Material Externo 


Acerca de Agrupacion 

Puedes profundizar acerca de agrupacion en campos de fecha, 
texto y numericos en el siguiente video: 


https://youtu.be/9yAAzfurX3c 
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Acerca de Ordenacion y Drill Down 

Para darle una lectura mas intuitiva a tus reportes de tablas 
dinamicas, es necesario ordenarlos de la mejor manera, en este 
video se profundiza en ello y, ademas se estudia el drill Down: 

https://youtu.be/sRPytmGiPtE 

Rangos de Consolidacion Multiple 

Esta es una funcionalidad que sigue disponible en Excel por 
cuestiones de compatibilidad mas que por otra cosa, con Power 
Pivot y Power Query utilizar rangos de consolidacion multiples 
queda relegado al olvido. Para los mas curiosos: 

https://youtu.be/sRPytmGiPtE 

Trucos, Tips y Macros (Mas Alla de lo Convencional) 

I- Referenda Cruzada - 

© LIBRO: Tablas Dinamicas La Quinta Dimension. Este libro tiene como 
objetivo brindar un conjunto de trucos y macros enfocados a Tablas 
Dinamicas, trucos que serviran tanto para la estetica del reporte, solution 
de tareas y automatization mediante macros. 


EL Siguiente Paso 

En este momento ya conocemos la interfaz, es tiempo de indagar 
en como agregar origenes de datos a la venta de Power pivot que 
es el tema del siguiente capitulo. 












La Presente Pagina se ha dejado en Blanco de forma deliberada. 




Capitulo 3 


Interfaz y Propiedades de Power Pivot 
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La Ventana de Power Pivot 


CANTIDAD MASIVA 
DE DATOS 

iComo maneja Excel 
millones de datos? 

En realidad, un archivo 
.xlsx o sus primos .xlsm y 
.xlsb, son un paquete 
comprimido como un Zip, 
este .zip puede cargar 
diferentes archivos, visto 
de una manera diferente, 
un archivo de Excel 
contiene dentro de sf 
multiples archivos de 
diversas gammas, es un 
.zip con una mascara .xlsx 
que transporta diversas 
cosas. Dentro de esta 
"maleta" se almacenan las 
cantidades masivas en 
formatos optimos para su 
procesamiento y poder 
llevarlos a cualquier lugar 
(cualquier pc, servicio en 
la nube, etc.) 


A diferencia de La gran mayoria de funcionalidades que utUizamos 
en Excel, Power Pivot cuenta con su propia ventana para trabajar, 
todos los datos que carguemos para crear calculos personalizados 
y realizar analisis se deben agregar a dicha ventana, donde se 
pueden ver, filtrar, ordenar, formatear, ocuLtar, etc. Esto no es 
extrano debido a que en Excel unicamente contamos con 
1,048,576 filas, pero Power Pivot nos permite trabajar con millones 
de registros (Filas), por ello para tener acceso u observar uno y cada 
uno de los datos se debe acceder siempre en la venta de Power 
Pivot, claro si la tabla de datos no fue anadida desde Excel. Sin 
embargo, tambien podemos hacer muchas manipulaciones desde 
La ventana de Excel, por ejemplo: Agregar y modificar medidas. 

Habilitar Power Pivot 

En el capitulo 1 se menciono cuales son las versiones y ediciones 
de Excel que cuentan con Power Pivot, para cualquiera de estas se 
debe habilitar, los siguientes pasos indican como. 

1) Vamos a La Pestana ARCHIVO y pulsamos clic en OPCIONES. 


Inicio 


Insertar Diseno de paging 


©I 


Pegar 


^ Carta r 
Hi] Copiar T 

Copiar formato 
Portapapeles 


Gill Sans MT 


12 


N K S 


Fuente 




A 1 

t | : 


.© 


Cuenta 
□ pci ones 
Comentarios 





Figura 3.1 - Section Opciones 












El ADN DE Power Pivot 



2) En el cuadro de dialogo Opciones que se despliega, vamos a la 
seccion COMPLEMENTOS y pulsamos clic, luego de ello en la 
parte inferior desplegamos las opciones de la lista desplegable 
y seleccionamos COMPLEMENTOS COM, para posteriormente 



Figura 3.2- Opciones de Excel, Complementos COM 


3) Con las acciones del paso dos lograremos desplegar el cuadro 
de dialogo COMPLEMENTOS COM, alii veremos una lista de 
varios complementos disponibles como Inquiere (Consulta), 
para este caso buscamos: Microsoft Power Pivot for Excel, 
seleccionamos la casilla que se encuentra en el extremo 
izquierdo y pulsamos clic en el boton Aceptar. 


4) Si la pestana POWER PIVOT no aparece, cerramos y abrimos 


nuevamente Excel (Reiniciar para que tenga efecto los cambios). 
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Pestana Power 
Pivot 


Pestana Power 
Pivot 



iComo ir a Power Pivot? 

Para ir a La ventana de Power Pivot tenemos dos opciones 
diferentes en Excel 2016. 

Vamos a la pestana POWER PIVOT grupo MODELO DE DATOS y 
pulsamos die en el comando ADMINISTRAR. 


Archive? 


Inicio Insert: Disen ( Formi Datos Revise Vista Desarr Power 



Modelo de dates 


Jx 

Medidas KPI 

Calculos 


Ag reg a r a Actu a I iza r D etecta r 

modelo de datos to do 


Tablas 


Relaciones 


Figura 3. 3 - Comando Administrar en la Pestana Power Pivot 


Tambien podemos ir a la ventana de Power Pivot en La pestana 
DATOS, grupo HERRAMIENTA DE DATOS, comando ADMINSITRAR. 


Datos Revisar Vista Desarrollador Power Pivot 


ei 

m 

A | Z | 

^Borrar 

Volver a aplicar 

|-*D 

M 

ZJ Ordenar 

Filtro " 

y Avanzadas 

Texto en ^ t | 

columnas >=© T 1*S | 


Ordenar yfiltrar 

Herramientas de datos 


Figura 3. 4 - Comando Administrar en la Pestana Datos 


jToma Nota! 

Para Excel 2010 y 2013 la unica forma de ir a la venta de Power Pivot 
es mediante la pestana POWER PIVOT, el comando ADMINISTRAR 
fue anadido al grupo HERRAMIENTA DE DATOS baj'o la pestana 
DATOS en la version de Excel 2016. 
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Para ir a La ventana de Power Pivot en esta ocasion vamos a utiLizar 
una tabLa de datos y anadirla mediante el comando AGERGAR AL 
MODELO DE DATOS que se encuentra en el grupo TABLAS de la 
pestana POWER PIVOT, lo hacemos asi para poder apreciar las 
distintas partes de la interfaz grafica de Power Pivot 


Agregar a l 
Modelo de 
Datos 


Archivo 


Inicio 


In&ertar Diseno de pagina Formulas Datos Revisar 


IS 

D& 

|i i| 

m 

Igg 


<? 

Administrar 

Medidas 

KPI 

Agregar a 

Actualizar 

Detecta r 

Configurator 


- 

- 

modelo de datos 

todo 



Modelo de datos 

Calculos 

Tablas 


Relaciones 



AA 


V* 


10 



A 

B 

c 

D E 

1 

i 

Num + Coip7| 

Nombre ' 

Cjc^] Certain erf^“| Minutes |~^| 


2 

9 Vilma 

Prueba Italia 

3.9 


3 

6 Fausto 

Prueba A!err, 

8.4 


4 

10 

Greg 

Prueba Italia 

3.9 


5 

A Alexa 

Prueba Portu 

7.0 



Dejar la Celda activa 
dentro de la tabla. El 
capitulo siguiente 
detalla aun mas los 
pasos y proporciona 
pautas para buenas 
practicas, aqui es solo 
para ver la interfaz de 
manera apropiada y 
explorarla mejor. 


Figura 3. 5- Agregar una Tabla de Excel a I Modelo de Datos 


Pulsamos clic en el comando AGREGAR AL MODELO DE DATOS 
dejando la celda adiva dentro dela tabla. jBienvenido a bordo! 


Ventana de 
Power Pivot 


I # a I 

| Inicio Diseno Avanzadas 

ft I? H 


Herramientas de tabla 


Power Pivot para Excel - Capitulo 3 (lnicio].xlsx 


6 l 


Tabla vinculada 

Tipo de datos:: Numero entero ” 
Formato: General T 


Pegar Obtener datos Actualizar Tabla 

I^H externos’ 1 ' inamica T S T ? .00 ■+.Q 

Portapapeles Formato 


z| SI Wl 

Borrartodos Ordenarpor Buscar 

los filtros columnar 

Ordenary filtrar Buscar 


[Nurm. Com., 


Num. Competidor T 

9 Vilma 
6 Fausto 


Nombre Competidor 


10 Greg 


Prueba Italia 3.9041922... 
Prueba Ale... 8.4312321... 
Pr r" L - ™ 


1 Cr 



Vista Parcial de la Ventana de Power Pivot. 


Figura 3.6- Primer Vistazo a la Pestafia de Power Pivot 



U Jo 


■ 

I* u 


Si! 
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Propiedades de la Ventana Power Pivot 

La ventana de Power Pivot sigue ciertas reglas al igual que sus 
elementos que derivan del desarrollo en Microsoft, conocerlas nos 
brindara la libertad de movernos con facilidad y seguridad en la 
interfaz y manipular los elementos con alta destreza. 

Entrelazamiento El Entrelazamiento de la ventana de Power Pivot senala que para 

cada libro (archivo) de Excel le corresponde una ventana de Power 
Pivot, por lo anterior, la ventana de Power Pivot siempre se llamara 
igual que su libro de Excel matriz. 



Las ventanas tienen el mismo 
nombre; Power Pivot lo 
diferencia precediendo con: 
Power Pivot para [Nombre del 
Archivo de Excel]. Bien sea que 
el archivo de Excel se guarde 
desde su propia venta o desde 
Power Pivot, ambos quedaran 
siempre con la misma 
denominacion. Como se 
menciono en la nota al principio 
de este capitulo, ambas viajan 
dentro de la "maleta" .zip, 
entrelazadas de forma univoca. 



c* - 0 

Inicio Insertai Diseno Formut 

<X> 


fatos Revisar Vista Desarrc Power I Diseno 

L 


0 Indicar Miguel G.. 


Q. Com parti r 


Tipo de datos: Numero entero » 
Formato: General » 


t para Excel - prueba.xlsx 


Tabla 

dinamica ▼ 


n 

*1 


T 


Borrartodos Ordenar por 
los filtros columna » 


Ordenar yfiltrar 


i 

Bi 


Nombre Competidor Qj Certamen 


Num. Competidor HI_ 

Figura 3. 7 - Propiedad de Entrelazamiento 


E 


Union La Union deriva de la propiedad anterior, basicamente hace 

referencia a que no se puede acceder a la ventana o 
funcionalidades de Power Pivot de Excel sin tener abierto un 
archivo de Excel previamente. Si bien el "DAX Engine" esta 
disponible en otros productos de Microsoft, espedficamente para 
Power BI, en ninguno de los casos podemos trabajar directamente 
con el lenguaje DAX sin ejecutar con anterioridad su ambiente. 
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La Cinta de Opciones 

tConocido no es asi ? Al igual que Excel, la ventana de Power Pivot 
esta organizada de la misma manera, con una cinta de opciones 
que contiene pestanas que agrupan comandos por afinidad y sub- 
grupos que encierran los comandos en categories mas pequenas 
y especificas, contamos con cuatro pestanas esenciales: 

■ Archivo (File) 

■ Inicio 

■ Diseno 

■ Avanzadas 


Adicionalmente pueden aparecer "pestanas contextuales" 
dependiendo del origen de datos que hallamos anadido, o de la 
tarea que estemos llevando acabo. 



Estas Pestanas 
aparecen por que se 
agrego una tabla 
desde Excel a Power 
Pivot. 


Figura 3.8- Cinto de Opciones en Power Pivot 


Estas Pestanas siempre 
esta disponibles. 



Pausemos un Momento 

Aunque puede ser tentador trabajar con Power Pivot de igual forma 
que Excel, esto no es del todo cierto, dado que en otros elementos de 
la interfaz hay cosas que varian, en algunas ocasiones puede tomar 
tiempo acostumbrarnos a ello, no obstante, encontraremos 
similitudes con funcionalidad de Excel que nos ayudaran. 
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Area de Tablas 


Todo origen de datos (Tablas) que necesitemos utilizar en el Modelo 
de Datos / Power Pivot se cargaran en esta parte de la ventana. Esta 
consiste en toda la zona central de la interfaz grafica de usuario. 


Barra de Formulas DAX, al igual 
que en Excel aqui se insertan las 
formulas y funciones que se 
desean utilizar, bien sea para 
crear columnas calculadas o 
medidas (esto se tratara en 
capitulos posteriores). 


Cinta de Opciones. 


Pnwer Pivnt nara Fxrel - nmeha.xlsx 


Hi 


a 


Portapapeles Obtener datos Actualizar Tabla 
” externos ▼ dinamica ’ 


Tabla vinculada 
Tipo de datos: - 
Formato: ' 

$ - % ? to! 
Formato 


* H 

Ordenar Buscar 
yfiltrar r 

I] Buscar 


£ Autosuma - 
If Crear KPI 


11 [ [ | Bq Vista de diagrama 

Uf) Mostrar oculto 
Vista de _ , 
datos E# Area de calculo 




P| Num. Competidor 

5 

■l^ombre Competidor C 

Certamen Q 

Minutos D 

Agregar columna 

' 9 

Vilma 

Prueba Italia 

3.9041922... 

1-1 

6 

Fausto 

Prueba Ale... 

8.4312321... 


3 

10 

Greg 

Prueba Italia 

3.9 


4 

4 

Alexa 

Prueba Port... 

7.0004103... 


5 

8 

Hank 

Pruba Espana 

8.8416147... 


6 1 

Eddy 

Pruba Espana 

6.0426495... 


\i 

10 

Greg 

Prueba Italia 

4.6796890... 


8 1 

Eddy 

Prueba Port... 

6.9327538... 


9 

8 

Hank 

Pruba Espana 

4.7517539... 


10 

10 

Greg 

Prueba Port... 

6.2004586... 


11 

6 

Fausto 

Prueba Port... 

4.1973814... 


12 

3 

Pedro 

Prueba Ale... 

6.9336623... 


Area de Tablas 


Prueba Italia 

3.3241692... 




7 47AA0flA 





Figura 3. 9 -Area de Tobias 


NOTA 

El aspecto del area de 
tablas, para ser precisos el 
color, es un cambio 
respecto a las versiones 
anteriores de Office, pues 
en sus predecesores es un 
tono verdoso, mientras 
que ahora es bianco. En 
defintiva cosmetica, nada 
de trascendencia aquf. 


Definicion y Objetivo 

El area de tablas como su nombre lo indica tiene como finalidad 
contener todas las tablas u origenes de datos a utilizar y/o integrar 
"Entretejer" er\ el modelo de datos de Excel; ademas, alii podemos 
filtrar, ordenar, renombrary expandir calculos con columnas que no 
estan originalmente en la base de datos (Columnas Calculadas es la 
denominacidn en Power Pivot) y dar formato para maximizar el 
analisis de datos. 
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Propiedades del Area de Tablas 

Este elemento de la interfaz de Power Pivot y en general del DAX 
Engine tambien tiene sus propiedades, pon especial atencion a las 
propiedades que se presentan enseguida. 

La propiedad Uno a Uno establece que a cada tabla o base de datos 
agregada a Power Pivot le corresponde una hoja de la ventana, por 
ello es imposible tener mas de una tabla en la misma hoja 



Uno a Uno 


0 

Numero de Pedido D 

Pais 

Ciudad Q 

SKU □ 

Tipo de ComJ 

' 

98069372 

Chile 

Vina del ... 

CCOI 

Normal 

2 

98069373 

Ecuador 

Quito 

L02 

Normal 

3 

98069374 

Colombia 

Medellin 

CBOI 

Normal 


< 

&a*Tabla2 s^TablaEl saiTabla4 Pedidos 

> 

Registno: M 4 1 de 24.S91 ► ►' 

B 

“n ,ss 


Cada una de las 
hojas corresponde a 
una sola tabla, en 
dichas hojas no 
pueden convivir mas 
de una tabla. 


Figura 3.10- Propiedod Uno o Uno del Area de Tobias 


La propiedad de Referenciacion Completa nos dice que en Power 
Pivot se trabaja con las columnas completas y NO con celdas 
individuales, es decir no existe tal cosa como referencia Al en 
Power Pivot. Por ejemplo, si queremos editar la celda 10 de la 
primera columna posicionandonos encima de ella y digitando algo, 
notaremos que no pasa nada, de la misma manera, si lo intentamos 
desde la barra de formulas DAX tampoco sucede nada, esto es asi 
porque la columna se trabaja en conjunto. En el capitulo cinco se 
trata esto con mas detenimiento. 


Referenciacion 

Completa 




























Capitulo 3 


Interfaz y Propiedades de Power Pivot 


Area de Medidas o Calculos 


NOTA 

En el area de medidas 
solamente puede ir 
medidas o "measures" en 
ingles y ningun otro tipo 
de calculo, por lo anterior, 
llamar esta parte de la 
interfaz de Power Pivot 
area de medidas es mas 
apropiado y preciso, pues 
cuando hablamos de 
calculos no extendemos a 
columnas calculadas, 
derivado de esto a partir 
de ahora en este libro 
llamaremos a esta parte 
de la interfaz: area de 
medidas. 


En Power Pivot distinguimos entre dos tipos de calculos 
personalizados: Columnas Calculadas y Medidas. Las Columnas 
Calculadas son columnas creadas en el area de tablas mediante 
operaciones entre otras columnas y utilizacion de funciones DAX, 
estas se elaboran en el extremo derecho de la tabla, donde dice 
Agregar Columna. 

Por otra parte, tenemos las Medidas (Hablaremos a profundidad en 
cada tipo de calculo en capitulos posteriores). Las medidas se crean 
en su propia zona de la interfaz. 

Definicion y Objetivo 

Las medidas son por naturaleza extremadamente diferentes a las 
columnas calculadas, ademas, son quienes brindan el mayor 
potencial para el analisis de datos, en capitulos posteriores se 
hablara largo y tendido sobre ellas, por el momento veamos la parte 
de la interfaz done residen y podemos ver el resultado de las 
medidas. 



Figura 3.11- Area de Medidas 
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jToma Nota! 



Para Power Pivot de Excel 2013 las Medidas se renombraron como 
Campos Calculados, pern para Power Pivot de Excel 2016 volvieron 
al antiguo nombre, Medidas, que fue como originalmente se llamo 
en Power Pivot para Excel 2010. Si el lector esta utilizando Excel 2013 
recuerde que cada vez que hablemos de Medidas nos referimos a 
campos calculados. 


La Barra de Estado 

La barra de estado nos permite movernos a diferentes partes de La 
tabla, ya que como en Power Pivot tenemos la posibilidad de cargar 
miLlones de datos, seria tedioso explorarlos solo con el Scroll, por 
esto Power Pivot los divide en grupos mas pequenos, la barra de 
estado tambien nos proporciona dos formas de ver el area de 
tablas: Cuadricula o Diagrama. 



Figura 3.12 - Barra de Estado en Power Pivot 


EL Siguiente Paso 


En este momento ya conocemos la interfaz, es tiempo de indagar 
en como agregar origenes de datos a la ventana de Power pivot que 
es el tema del siguiente capitulo. 


















La Presente Pagina se ha dejado en Blanco de forma deliberada. 




Capftulo 4 


Agregar Bases de Datos a Power Pivot 
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Fuentes de Datos Comunes 


NOTA 

Es muy diffcil encontrar un 
origen de datos que no se 
pueda cargar en Power 
Pivot, claro los hay, pero 
los presentados son los 
mas comunes y 
ampliamente utilizados, 
de hecho, es diffcil que un 
unico usuario utilice todas 
las fuentes de datos que 
se mencionan. 


Para producir reportes con El Modelo de Datos / Power Pivot en 
Microsoft Excel es necesario cargar o agregar bases de datos de uno 
o varios origenes, integrarlos, determinar calculos relevantes y 
crear reportes potentes y robustos. 

Power Pivot puede obtener datos de una variedad sorprendente de 
origenes, para resumirlo un poco mas vamos categorizar las fuentes 
en seis tipos: 

1) Tablas Vinculadas: .xlsx, .xlsx, .xlsm, xlsb. 

2) Archivos de Texto: .txt, .CSV, .Inf, etc. 

3) Bases de Datos Relacionales: MS SOL Server, Access, Oracle, etc. 

4) Estructuras Multidimensionales: SOL Server Analysis Servicies. 

5) Fuentes en la Nube: SOL Azure, Azure Data Market. 

6) Data Feeds: RSS, SSRS, etc. 

Ademas, estos tipos los vamos a dividir en dos grandes categorias 
generales: 


■ Fuentes de datos Comunes: Del 1 al 3 

■ Fuentes de datos alternas: Del Aal6 


Tablas Vinculadas 

Las tablas vinculadas son la forma mas facil de alimentar Power 
Pivot, de hecho, si algun origen de datos no se puede cargar 
directamente a Power Pivot, convertirlo en una tabla de Excel 
puede ser la solucion al problema. 


El ADN DE Power Pivot 




Es una buena practice convertir La tabla de datos en Excel en una 
tabla estructurada, es decir, pulsar la combinacion Ctrl +T y aceptar 
en el cuadro de dialogo que se despliega, adicionalmente, 
brindarle un nombre descriptivo facilita el entendimiento del 
archivo. 


Tabla 

Estructurada 






Capftulo 5 (Final).xlsx - Excel 


Resumir con tabla dinimica 
hi Quitar duplicados 


13^ramE!artaman^elataUIa Convertir en rango 
Propiedades 


Herr... 

s 

□ 

Pi\ Diseno Q Indicar 

Miguel C... 

P+ Comparti 

m Xs 
LcOil' 

m 

ip 

Exportar Actualizar „ 

O^tiojTes de 

Estilos 

- - c ,p 

Datos externos de tabla 

estilo detatita<^ 

^rapidos ” 
EstiloS'-d^t^. 





B6 


X ✓ 

^98Q69375 


B 


_ 


Numero de Tipo de 
Pedido _g Compra 


D 

SKU Categoria de 
_[g Descuento g 



3 

98069372 

CCOI Non 

105.06 

4 

98069373 

L02 Cyber Monday 

96.48 

5 

98069374 

CB0I Non 

444.06 

6 


98069375 

CCOI Non 

105.06 

7 

98069376 

CI2 

29.84 

8 

98069377 

L07 

37.89 

9 

98069378 

L02 

120.60 

10 

98069379 

L07 

37.89 

II 

98069380 

Normal LOI 

61.50 


Basde de Datos I 


SKU Producto(s) I Categoria 


... ® 


Se puede identificar 
que es una tabla 
estructurada por las 
flechas de filtro y la 
pestana DISENO que 
aparece cuando se 
deja la celda activa 
dentro de la tabla. 


Inmediatamente 
despues de crear la 
tabla, debemos 
asignarle un nombre 
descriptivo. 


Figura 4.1- Tablo Estructurada de Excel con nombre descriptivo 


jToma Nota! 



Se puede cargar la tabla sin necesldad de convertirla en una tabla 
estructurada, pern estos es una MUY MALA IDEA, es mas, sino se 
renombra la tabla antes de agregarla a Power Pivot, mostrara el 
nombre por defecto en el panel de campos de tabla dinamica 
siempre, y nadie entlende que contiene tabla!, tabla2, etc. jSIGUE LAS 
BUENAS PRACTICAS! 
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Agregar al 
Modelo de Datos 


Para agregar la tabla de datos al modelo de datos debemos dejar la 
celda activa dentro de la tabla, para posteriormente ir a la pestana 
POWER PIVOT, grupo TABLAS y pulsar clic en el comando AGREGAR 
AL MODELO DE DATOS. 



Como dice el tooltip del comando, las tablas vinculadas son un 
vinculo activo entre la tabla de Excel y la tabla en Power Pivot, por 
lo que las actualizaciones en la tabla de Excel refrescan la tabla en 
el modelo de datos "instantaneamente". 



Herramientas de tabla Power Pivot para Excel - Capitulo 5 (Final).xlsx 


Tabla vinculada 


© 


A 


Portapapeles Obtener datos Actualizar 
”• externos - 


Tabla 
dinamica -r 


Tipo de datos: Texto ’ 
Formato: Texto » 


* M 


oo 0rdenar Buscar 
% ? .66 4 yfiltrar' r 


£ Autosuma T 

Crear KPI 


I Vista de diagrama 

23 Mostrar oculto 
Vista de , 
datos Area de calculo 


TPa's] 



Numero de Pedido E 

Pais 0 

Ciudad E 

SKU P 

Tipo de Compra C 

Categoria de Descuento E 

Prec 

1 

98069372 

(Chile 

Vina del ... 

CCOI 

Normal 

Non 


2 

98069373 

Ecuador 

Quito 

L02 

Normal 

Cyber Monday 


3 

98069374 

Colombia 

Medellin 

CBOI 

Normal 

Non 


4 

98069375 

Paraguay 

Asuncion 

CCOI 

Normal 

Non 



5 98069376 Peru Lima Cl2 Normal Non 


Figura 4.3- Tabla Agregada a Power Pivot 
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Ventajas y Desventajas de las Tablas Vinculadas 


En las dos tablas a continuacion se detallan las ventajas y 
desventajas de agregar datos con tablas vinculadas. 


Ventajas de las Tablas Vinculadas 


Ventaja 

La forma mas intuitiva de agregar tablas. 

Cambios en Excel se Reflejan en Power Pivot “Enseguida”. 
Columnas nuevas en Excel aparecen en Power Pivot. 



Desventajas de las Tablas Vinculadas 


NOTA 

El archivo de Excel puede 
ser en formato: .xlsx, .xlsm 
o .xlsb y no tendremos 
ningun inconveniente en 
utilizarlo en Power Pivot, 
por lo tanto, crear tablas 
vinculadas desde 

cualquiera de estas 
extensiones que tenga el 
archivo matriz es 
perfectamente valido. 


Desventajas 

Cargar mas de 50 mil datos no es optimo con este metodo. 

No se puede vincular una tabla que se encuentre en otro archivo de Excel diferente al Matriz. 


iComo agregar tablas en otros libros? 

Las tablas vinculadas tienen la limitante de NO poder anadir tablas 
desde un archivo de Excel diferente. Sin embargo, si contamos con 
una alternativa para agregar tablas de otros libros a la ventana de 
Power Pivot actual, a continuacion, se describe como hacerlo. 

Nos situamos en la ventana de Power Pivot, vamos a la pestaha De Otros 

INCIO grupos OBTENER DATOS EXTERNOS y pulsamos clic encima Orfgenes 

del comando DE OTROS ORIGENES, con esto se despliega el cuadro 
de dialogo: ASISTENTE PARA LA IMPORTACION DE TABLAS. 
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Esta opcion nos permite cargar 
tablas desde otro archivo de 
Excel, lo seleccionamos y 
pulsamos clic en el boton 
siguiente que se encuentra en la 
parte inferior. 



Asistente para la importacion de tablas 

Conectarse a un origen de datos 

Puede crear una conexion a un origen de datos o bien, puede usar una que ya exista. 


Fuentes de distribucion de datos • 


Informe 

jfi] Cree una conexion a un informe de Microsoft SQL Server Reporting Services. 
Importe datos de la fuente. 

De Microsoft Azure Marketplace 

S' Obtenga datos externos de Microsoft Azure Marketplace. 


Sugerir datos rdadonados 

Obtenga sugerencias de datos externos. 


Otras fuentes 

Cree una conexion a una fuente de distribucion de datos. Importe datos desde la 
fuente. 


Archivos de texto - 


Archivo de Excel 

Importe datos desde un archivo de Excel. 

Archivo de texto 

.[f] I mportar datos deun arch i vo de texto. 


<** [ Siguiente > | 


Figura 4. 4- Asistente poro lo Importacion de Datos 


Scroll Down En el cuadro de dialogo nos desplazamos hasta la parte final con el 

Scroll de nuestro mouse, alii veremos: Archivos de Excel, 
seleccionamos la opcion y pulsamos clic en siguiente. 


Pulsamos clic en el boton 
Examinar para localizar el 
archivo de Excel que alberga la 
tabla que necesitamos 


Activar esta casilla si nuestra 
tabla tiene encabezados, asi 
Power Pivot los detectara 
automaticamente, 


Asistente para la importacion de tablas 

rosoft Excel 

necesaria para conectar coin el archivo de Microsoft Excel. 



t^ombre descriptive de la conexion: |Excel TABLA_SKUPnoductos 
Ruta de acceso del a rch ivo de Excel : |C:\Miguel\Free Editorial\EFB\C - Produc 


Usar primera fi la comoencabezados de columna. 


X 



Ava nzadas ... Proba r conex ion 


Figura 4.5- Buscar y Seleccionar Archivo de Excel 










































El ADN DE Power Pivot 



Ahora se mostraran todas Las hojas que tengan el archivo de Excel, 
para este ejemplo solamente aparece una con nombre: 
SKU_Producto(s). Seleccionamos la tabla deseada y clic en 
siguiente. 


Asistente para la importacion detablas 

? 

X 

Selecckme las tablas y vistas 

Selectione las tablas y vistas de las que desea importar datos. 




C:\Miigud\Free Editorial'.EFB'.C - Productos (Development Product) 
Nombre de archivo: \Coleocion ADN de EF&.EL ADN de Power Pivot (Feb 2 i C i 1G) l, .Capitulo 4 
IT ABLA_SKU Prod uotos xlsx 

Tables y vistas: 


0 

Tabla de origen 

Nombre descriptive 

Detalles defiltno 

eg 

’SKU Fnoducto(s)$ ,, 

SKU F'roductos 



HOJA NO TABLA 

El Asistente muestra las 
hojas que tiene el libro, 
mas no las tablas que 
contiene, por esto 
asegurate que su archivo 
de Excel tenga una tabla 
por hoja. 


Figura 4. 6 - Seleccionar Tobias y Vistos 


Asistente para la importacion detablas 


? X 


Imporfando 

Puedeque la operation de importation durealgunos minutos. Para detenerla, haga 
clicen el botdn Detener importation. 



Correcto 


Total: 1 Cancelado:0 
Correcto: 1 Error: 0 


Detalles: 



□emento de trabajo 

Estado 

Mensaje 

0 

SKU Productos 

Comecto. Se han transferido SSfilas. 



Figura 4. 7 -Tabla Importada Correctamente 


NO VINCULADA 

Importar tablas de Excel es 
diferente de tablas 
vinculadas, dado que 
cuando se importa se crea 
una copia en Power Pivot, 
por lo tanto, los datos NO 
se actualizan cuando se 
modifica el archivo de 
Excel original de donde se 
tomaron los datos. 


Clic en cerrar y ya tenemos La tabla en su propia hoja en la ventana 
de Power Pivot. 
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Archivos de Texto 


ARCHIVO DE TEXTO 

Un archivo de texto tiene 
como finalidad almacenar 
texto sin ningun tipo de 
formato, unicamente 
caracteres, se diferencia 
de los archivos de Excel 
porque no tiene la 
posibilidad de 

proporcionar, negrita, 
cursiva, etc. Y muchos 
menos colores o formatos 
mas sofisticados. 

Su estructura los vuelve 
apto para almacenar 
cantidades masivas de 
datos sin ningun 
inconveniente. 

Un ejemplo comun de un 
archivo de texto es el: CSV 
(Comma Separated 
Values). 


Las tablas vinculadas y los archivos de Excel, son sin lugar a dudas, 
la fuente de datos mas utilizada, sin embargo, una que iguala su 
importancia casi por completo son los archivos de texto. 

Uno de los archivos de textos mas usados es el CSV, este representa 
los datos en una linea de texto normal, cada linea contiene una fila 
o registro de datos y a su vez define las columnas separadas por 
comas, veamos como cargar la tabla: Categoria_de_Productos CSV al 
Modelo de Datos / Power Pivot 



Estando en la ventana de Power Pivot, vamos a la pestana INICIO 
donde debemos localizar elgrupo OBTENER DATOS EXTERNOS, una 
vez alii pulsamos clic en el boton DE OTROS ORIGENES, con lo cual 
aparece el ASISTENTE PARA IMPORTACION DE DATOS. 
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La figura 4.4 muestra el cuadro de dialogo, a continuacion, nos 
desplazamos hasta la parte final y seleccionamos Archivo de Texto, 
para posteriormente pulsar clic en el boton siguiente. Vease la 
figura 4.4. Con los pasos especificados, aparece el asistente para 
importacion de datos, listo para cargar datos de texto. 


Asistente para la importacion detablas 

7 

X 


Co nectar a archivo piano 

Especifique la informacion necesaria para obtenerdates dearchives pianos. 





Ruta de acceso del archivo: 


Sepa rador de col u m na : 


(Text 



1 - 

Btaminar... 



Coma (,) v 


Avanzadas 


| | Usar primera fila como encabezados de columna 



Si sabemos que la primera fila 
tiene las etiquetas de columnas, 
entonces debemos seleccionar 
esta opcion. 


< Airis 


Siguiente > 


Finalizar 


Cancelar 


N 


Cuando se carga el CSV 
este nombre se define 
como el nombre del 
archivo precedido por la 
palabra Text, se puede 
personalizar si se desea. 


Buscamos en nuestro 
computador el CSV 
deseado. 


El separador puede ser 
diferente de coma (,) esta 
lista desplegable nos 
proporciona los 
caracteres mas comunes 
y podemos seleccionar el 
que se ajuste al archivo, 
estos caracteres son: (;) () 

C) (I) 


Figura 4. 9 - Asistente para importar archivos pianos 



jToma Nota! 

Puede suceder que el caracter que sirve como delimitador de 
columnas no se encuentra en la lista desplegable, con lo cual el 
asistente no puede cargar correctamente los datos, no obstante, 
existen tecnicas para poder hacerlo, pern esta por fuera de lo tratado 
en este libro. 
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Una vez especificados to parametros, aparece un Preview en el 
asistente donde podemos omitir columnas si no las necesitamos. 


Asistente para la importation detablas 

Conectar a archive piano 

Especifique la informacion necesaria para obtener dates de arctiivos pianos. 


X 


Jlom bre descri pti vo de la conexion : |Text TABLAjCategonaDeProductos 
Ruta de aooeso del archive: 


Sejja rador de col u m na : 


Coma (.) 


0 LJsar primera fila como encabezados de columna 


Borrarfiltros de fila 


EKaminar... 


Av^anzadas 


I'f S.. T 

Q Cat... D 

Q Precio de ... Dl 

1 LQI 

Libro 

30.75 

2 LQ2 

Libro 

40.2 

3 LG 3 

Libro 

29.99 

4 L04 

Libro 

30.1 

5 LOS 

Libro 

40.55 

6 LG 6 

Libro 

42.55 

7 LG 7 

Libro 

37.89 

8 LOB 

Libro 

50.99 

9 DO 1 

DVD 

25 v 




<^ras 

Siguiente > 

Finalizar 

Cancelar 






Figura 4 .10- Preview de la tabla en el osistente 


Clic en el boton finalizar y empieza a cargar los datos hasta que 
notifique que se ha realizado con exito, una vez el proceso haya 
finalizado pulsamos clic en el boton cerrar. Podremos ver la tabla 
en su propia hoja en la ventana de Power Pivot. 
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Ventajas y Desventajas de Archivos de Texto 

En Las dos tablas se detallan las ventajas y desventajas de agregar 
datos al modelo de datos con archivos de texto. 



Ventajas de Los Archivos de Texto 


Ventaja 

La forma mas rapida y eficiente de cargar millones de registros. 
Se pueden agregar columnas despues. 

Se pueden devolver a un estado anterior del archivo de texto. 



Desventajas de Los Archivos de Texto 


Desventajas 

El Separador de Columna no puede estar listado. 


Modificaciones y actualizaciones en el archivo fuente, como 
cambio en las posiciones de las columnas o renombrar las 
columnas, puede alterar como Power Pivot entiende el archivo. 


Desconectar Tablas 

Es muy importante conocer como desconectar o quitar una tabla 
que se ha cargado a Power Pivot, son muchas las razones por esto, 
en nuestro caso resulta que la tabla Pedidos que se relaciono como 
tabla vinculada, es en realidad una tabla de una base de datos de 
Access que se actualiza constantemente (Diariamente para esta 
situacion) por esto es mejor conectarla directamente desde Access 
y hacer actualizaciones diarias. Esta es una sencilla justificacion 
para saber como eliminar tablas de Power Pivot. 
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Realizar la "eliminacion" de la tabla del modelo de datos es 
bastante facil, los podemos hacer desde Power Pivot o desde Excel, 
veamos ambas alternativas. 


Desconectar las Tablas desde Excel 

Nos dirigimos a la ventana de EXCEL, alii buscamos la pestana 
DATOS, grupo CONEXIONES, para finalmente localizar el comando 
con el mismo nombre, CONEXIONES. 



Figura 4.11- Cuadro de didlogo Conexiones 


Seleccionamos la tabla deseada para posteriormente pulsar clic 
encima del boton OUITAR en el cuadro de dialogo. Observa como al 
final aparece ThisWorkbookDataModel indicando que existe 
conexiones con Power Pivot, si este ultimo este seleccionado el 
boton quitar parece deshabilitado. 
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Desconectar las Tabas desde Power Pivot 

Remover una tabla del modelo de datos desde la ventana Power 
Pivot es mas sencillo de lo que se puede esperar; solamente 
pulsamos clic derecho encima de la hoja que contiene la tabla 
deseada y en el menu contextual localizamos la opcion eliminar. 


23 

24 


98069394 Venezuela C 
98069395 Brasil R 


Eliminar 

Cambiar nombre 
Mover 

Description... 

Ocultar en herramientas cliente 
^ Mostrar area de calculo 


orfaDeF 


Registro: M 


1 de 24.891 


Figura 4. 12 - Eliminar tabla desde Power Pivot 


NOTA 

En Power Pivot tenemos el 
comando conexiones 

existentes, pero es una 
experiencia diferente y tal 
vez puede causar cierta 
confusion. La 

recomendacion es utilizar 
el cuadro de dialogo 
conexiones desde Excel o 
eliminar la hoja asociada a 
la tabla de forma directa. 


Aparece un mensaje diciendo: ^Esta seguro que desea eliminar de 
forma permanente esta tabla, incluidos sus medios asociados? Que 
es precisamente la accion que queremos ejecutar, pulsamos clic en 
SI. Con lo anterior se remueve la tabla de Power Pivot, se puede 
verificar en el cuadro de dialogo conexiones. 


Bases de Datos Relacional 

Las bases de datos relacionales brindan la posibilidad de 
interconectar diversas tablas de manera logica y asi trabajar de 
manera eficiente y ahorran espacio en memoria. Existen un buen 
numero de software dedicados a esto, enseguida se listan los mas 
populares. 
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Gestores de bases de datos mas Populares: 


NOTA 

Incluso si encuentras dificil 
anadir una base de datos 
de alguna fuente no 
listada, acudir a Power 
Query como intermediaria 
puede ser la solucion, ya 
que esta destinado a 
cumplir con el proceso 
ETL, su variedad de 
opciones y posibilidades 
para cargar datos en 
muchfsima mas amplia 


■ Microsoft Access 

■ Microsoft SQL Server 

■ MySQL 

■ PostgresSOL 

■ Oracle 

■ IDMDB2 

■ Sybase 

■ Terada 

■ Informix 

Power Pivot incrementa sus posibilidades cada vez mas, por lo que 
encontrar un comando especial para conectarse a una base de 
datos relacional que se ajuste a la nuestra es bien facil, en este libro 
no veremos todas las opciones, solo abarcaremos Microsoft Access, 
no obstante, puedes encontrar toda la documentacion necesaria 
para cada una de ellas en el MSDN de Microsoft. 


Microsoft Access 

A continuacion, se muestra la tabla pedidos en Access. 


La tabla pedidos se encuentra 
en una base de datos de 
Access originalmente, puesto 
que se actualiza diariamente 
es mejor cargarla a Power 
pivot directamente desde el 
gestor. 


0 *3 C* T ▼ TABLAS_Pedidos (Base de Datos Relacional): Base de datos- G\Mi... HERRAMIENTAS DE TABLA 

I INICIO CREAR DATOS EXTERNOS HERRAMIENTAS DE BASE DE DATOS CAMPOS TABLA 

Cortar z I Ascendente ^ Seleccion» |F^j i=] Nuevo ^ Totales 

c=:3 ’—' IT^i Copiar aI Descendente Avanzadas - ^Guardar Revision or 

Ver Pegar # Filtro . Actualizar 

' Copiar formato zj Quitar orden y Alternar filtro todo” ^ Eliminar - Mas 1 - 


Portapapeles 


Ordenaryfiltrar 


Registros 


Todos los ob...© « 

Buscar... [jQ| 

Tablas it 

S3 TABLA_Comerciales 
H TABLA_Departamentos 
S3 TABLA_GestoresLogisti... 
H TABLA.Pedidos 


g TABLA_Pedidos 


Numero de - Tipo de Co - 

SKU 

- Categorfa c - 

Precio de V - 


Normal 

CC01 

Non 

105.06 


98069373 Normal 

L02 

Cyber Monda 

96.48 


98069374 Normal 

CB01 

Non 

444.06 


98069375 Normal 

CC01 

Non 

105.06 


98069376 Normal 

C12 

Non 

29.84 


QQHAQ377 n^\//^ili i/-i/Sn 

1 07 


37 QQ 


Figura 4.13 - Tabla Pedidos en su fuente original, Access 
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Nos dirigimos a la pestana INICIO, grupo OBTENER DATOS 
EXTERNOS, comando de OTROS ORIGENES, en la seccion Bases de 
datos relacionales ubicamos la opcion MICROSFT ACCESS. 



De Otros 
Origenes 


Asistente para la importacion detablas ? X 

Conectarse a un origen de datos 

Puede crear una conexion a un origen de datos o bien. puede usar una que ya exista. 


Bases de datos relacionales 


a 

a 

a 


Microsoft SQL Server 

Cree una conexion a una base de datos de SQL Server. Importe tablas o vistas 
desde la base de datos o datos que haya devuelto una consulta. 

Microsoft SQL Azure 

Cree una conexion a la base de datos SQL Azure. Importe tablas o vistas desde la 
base de datos o datos que haya devuelto una consulta. 

Almacenamiento de datos paraleios de Microsoft SQL Server 

Cree una conexion a un almacenamiento de datos paraleios de SQL Server. 
Importe las tablas o vistas de la base de datos o bien. los datos que haya devuel... 



B 

B 

B 


Oracle 

Cree una conexion a una base de datos de Oracle. Importe tablas o vistas de la 
base de datos o datos que haya devuelto una consulta. 

Teradata 

Cree una conexion a una base de datos de Teradata. Importe tablas o vistas desde 
la base de datos o datos que haya devuelto una consulta. 

Sybase 

Cree una conexion a una base de datos de Sybase. Importe tablas o vistas desde 
una base de datos o datos que haya devuelto una consulta. 


v 


Figura 4.14 - Conectar Access 


Una vez encontrada la opcion pulsamos clic en el boton siguiente, 
alii en el segundo paso del cuadro de dialogo pulsamos clic en 
boton examinary buscamos la base de datos. 


Buscar Base 
de Datos 


Asistente para la importacion detablas ? X 

Conectarse a una base de datos de Microsoft Access 

Escriba la informacion necesaria para conectarse a la base de datos de Microsoft 
Access. 

Nombre descriptivo de la conexion : |Access TABLAS_Pedidos Base de Datos Reladonal 
Nombre de la base de datos: |C:\Miguel\Free Editorial\EFB\C - Productc | Examinar... | 

Inidar sesion en la base de datos 
Nombre de usuario: f” 

Contrasefia: 

□ Guardar mi contrasefia 


Figura 4.15 - Ubicar base de datos de Access 
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NOTA 

Es una excelente practica 
importar las columnas, 
registros y claro, tablas 
estrictamente necesarias, 
dado que nos 
proporciona mayor 
flexibilidad y velocidad, 
ademas, la facilidad de 
volver y poder integrar 
otras columnas o registros 
es agil, facil e intuitivo. 

En el caso de querer 
extraer un conjunto de 
datos de una tabla, 
entonces, debemos 
escoger la opcion: Escribir 
una consulta que 
especifique los datos a 
importar, allf el cuadro de 
dialogo nos brinda el 
espacio para escribir la 
consulta SQL. Por 
ejemplo, si solo 
necesitamos las columnas 
SKU, Pafs y Ciudad 
escribimos: 

SELECT SKU, Pafs, Ciudad 
FROM TABLA_Pedidos. 


Pulsamos die en siguiente, alii dejamos la opcion por defedo: 
seleccionar en una lista de tablas y vistas para elegir datos a importar. 
Pulsamos clic en siguiente. A continuacion, nos despliega todas las 
tablas y vistas de la base de datos, para este caso unicamente 
contamos con tablas, cuatro tablas para ser exactos, seleccionamos 
TABLA_Pedidos que es la que necesitamos. 


Asistente para la imports don de tablas ? X 

Seleccione las tablas y vistas 

Seleccione las tablas y vistas de las que desea importar datos. 


C: 1 ',Miguel 1 ',Free Editorial\EFBC - Productos (Development Product)\Co!eoci6n 
Basededatos: ADN de EFB\EL ADN de Power Pivot [Feb 201G)\Capitulo 4YTABLAS_Pedidcs 
(Basede Datos RelacionalJ.accdb 


Tablas y vistas: 


□ 

Tabla de origen 

Nombne descriptive 

Detalles de fittru 

□ 

m 

TAB LA Comenciales 



□ 

h 

TABLA Departamentos 



□ 

m 

TAB LA Gestores Logisticos 



0|q_ 

TABLA_Pedidos 

TABLA_Pedidos 




Figura 4 .16- Seleccionar Tabla de Access 


Ventajas de los Gestores de Bases de Datos 



Ventajas de los Gestores de Bases de Datos 


Ventaja 

Manejo agil de cantidades masivas de datos. 

Modificadones son captadas por Power Pivot adecuadamente. 



Se puede devolver a un punto anterior de la base. 
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Fuentes de Datos Alternas 


La segunda gran categoria de fuentes de datos son menos 
utiLizadas y aqui no nos detendremos mucho en ellas, unicamente 
daremos un vistazo a Microsoft Azure Marketplace. 


iQue es Azure Marketplace? 


NOTA 


Microsoft Azure Marketplace pertenece a la familia de Microsoft 
Azure que ofrece la plataforma como servicio, en particular, Azure 
Marketplace es un mercado On-line que nos permite comprar y 
vender software como servicios (SaaS) es decir crear programas, 
alojarlos, mantenerlos en la nube y proveer un cliente; ademas 
Azure Marketplace es un mercado de datos en linea global, donde 
podemos comprar bases de datos, imagenes, datos comerciales y 
datos publicos acreditados. En este momento la ultima parte es la 
que nos interesa, comprar u obtener bases de datos en linea, ya 
que con ello podemos captar datos que de otra manera seria muy 
dificil de acceder y llevar acabo analisis. 


Es importante que crees 
una cuenta en Microsoft 
Azure con tu cuenta de 
Outlook, para poder 
obtener datos desde el 
Marketplace a Power Pivot 
de manera apropiada, si 
bien el servicio es de 
pago, podemos optar por 
la opcion de un mes 
gratuito y despues seguir 
usando los servicios sin 
costo alguno, siempre y 
cuando seleccionamos 
cosas gratuitas. 


En Microsoft Azure Marketplace podemos encontrar tanto bases de 
datos gratuitas como de pago. 

De Servicios de Datos 

Vamos a la pestana INCIO en la ventana de Power Pivot y en el 
grupo OBETNER DATOS EXTERNOS ubicamos DE SERVICIOS DE 
DATOS, desplegamos las opciones y seleccionamos DE MICROSFT 
AZURE MARKETPALCE, con lo anterior se despliega el asistente para 


Por seguridad la 
plataforma nos pide una 
tarjeta de credito y 
verificar de que se trate de 
una persona, no te 
preocupes por esto, 
Microsoft no cobrara nada 
sin un permiso explicito de 
nuestro parte, solo es por 
verificacion. 


la importacion de datos. Vease la imagen a continuacion. 
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En el search box digitamos: 
DateStream. Esta es una 
fuente de datos bastante 
popular, utilizada en el 
modelo de datos, 100% 
gratuita, contiene informacion 
para crear tablas de 
calendario, muy importante 
en Power Pivot. 


Asistente para la importacion de tablas 


la fuente de distribucion de datos. 


|https://datamarketazure.com/embedded/catalog?client_id=PowerPivotExcel15&require_query=true&require_authcode=true 


Microsoft 

Azure 

Marketplace 


Catalogo 



PRECIO 

Gratuito (144) 

De pago (102) 

Prueba de evaluacion 
gratuita (41) 
CATEGORIA 
Agriculture p 

lologia y 
electronica (14) 
Automocion, Industrial y 
Aeroespacial (14) 

Bienes de consumo y 
distribucion (12) 

Bienes inmuebles (24) 
Ciencia y estadfstica (49) 
► 

Comunicaciones (16) ► 
Data Quality Services (13) 
Datos demograficos (47) 
Deportes y juegos (6) 
Fabricacion (14) ► 
Gobiemo (31) 

Machine Learning (39) 
Machine-to-Machine (6) 
Medios de comunicacion 
y entretenimiento (4) 


201 Resultados en: | datos | 
Ordenar pon Fecha en la que se agrego 



AppWd 


^unidpios e Localidades do Brasil 

Jorge Chavez 

Informacoes do IBGE e Geolocalizacao dos Municipios e Localidades Brasileiras 

HealthMethods Public Health Intelligence 

Applied Methods Inc 

HealthMethods Public Health Intelligence uses machine learning to create groups of indicators based 
on a set of feature values for local, state, and country levels and a score for the relative position. The 
service area intelligence query returns samples. 

HealthMethods Provider Metrics 

Applied Methods Inc 

Each query returns demographic, socioeconomic, and healthcare cost, quality, and utilization data. 
The sample queries, Diagnosis Metrics and Service Area Metrics, do not return real data. 


EUHealth Data Service UK 

EUHealth ^e^ 


EUHealth has over 500 various contact job functions in Clinical Positions. Definitive European 
healthcare contacts and planning directives database - 22 in full, additional countries in the Europe. 
We are currently offering UK Contacts on DataMarketPlace 

CRM Enumeration Codes 


Figura 4 .17 - Asistente para importacion, desde servicio de datos 


DateStream en 
el Catalogo 


Pulsamos clic encima del 
nombre DateStream. 


Asistente para la importacion de tablas 


Conectarse a una fuente de distribucion de datos 

Escriba la informacion necesaria para conectarse a una fuente de distribucion de datos. 


|https://data market azure.com/embedded/ca talog?client_id=PowerPivotExcel15&require_query=true&require_authcode=true&query=date 


“ Catalogo 

Marketplace 



Hola, Miguel Caballero Cerrar sesion 

\Busca^r^arketplac^^ 


Anunciante 


DateStream 

Boyan Penev 

Date table feed designed for import into an Excel PowerPivot model. The 
table contains columns particularly suitable for time business intelligence 
applications. Delivered through the Azure Data Market, it is effortlessly 
available through the PowerPivot window in Excel. _ 


Terminos de uso | Privacidad y cookies 


Figura 4. 18 - DateStream filtrado en el catalogo 


I 
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Pulsamos clic en La ventana siguiente en datos gratuitos, despues 
apareceran Los nombres de las tablas que deseamos consultar, 
selecdonamos unicamente BasicCalendarEnglish y clic en el boton 
SELECCIONAR CONSULTA. Posteriormente elegimos la tabla en el 
asistente, y clic en finalizar. 


Seleccionar 

Consulta 


Asistente para la importacion de tablas ? X 

Conectarse a una fuente de distribudon de datos 

Escriba la informadon necesaria para conectarse a una fuente de distribudon de datos. 


jaboutblank 


Microsoft 

Azure 

Marketplace 


DateStrearr - por Boyan Penev 


Hola, Miguel Caballero Cerrar sesion 


H BasicCalendarEnglisfi 


—BasicCalendarUS—□—ExtendedCalendar—□—BasicCalendarOanish—□—BasicCalendarGerman—□—BasicCalendarHebrew—□“ 
| | HourMinute Ell HourMinuteSecond 


Se muestran 20 de 73414 filas 

DateKey ' I Datelnt X I YearKey QuarterOfYear X I MonthOfYear X I DayOfMonth X I MonthName < I MonthlnCalendar 

Sun Dec 31 19000101 1900 1 1 1 January Jan 1900 

1899 19:00:00 
GMT-0500 
(SA Pacific 
Standard 
Time) 

Mon Jan 01 19000102 1900 1 1 2 January Jan 1900 

1900 19:00:00 


Temninos de uso | Privacidad y cookies 

< 


Unicamente dejamos 
seleccionado 
BasicCalendarEnglish, con 
esto solo importaremos 
los datos del calendario 
ingles. 


Figura 4.19- Seleccionar BasicCalendarEnglish 


Si pulsamos clic en el comando CONEXIONES EXISTENTES del 
grupo OBTENER DATOS EXTERNOS podremos ver todas las fuentes 
que tenemos hasta el momento. 


Seleccionar 

Consulta 


Conexiones existentes ? X 

Seleccionar una conexKxi existence 

Sdecdone una conexion a un origen de datos que contenga los datos que quiere 
importar. 


Seleccione una conexion de origen de datos: 
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Unas palabras acerca del resto de fuentes 

■ Estructuras Multidimensionales: Podemos integrar datos 
desde otros productos destinados al analisis como SSA5 
(SQL Server Analysis Servicies) 

■ Data Feeds: En Las empresas nos podemos encontrar con 
reportes, es posible que queramos importar Los datos de 
dichos reportes y crear nuestros propios analisis. Power 
Pivot soporta La carga desde SSRS (SQL Server Reporting 
Servicies) 


Fuentes Pavorosas 

Creepy Sources 

En Power Pivot para Excel tenemos la posibilidad de cargar datos al 
modelo sin necesidad de una conexion a una fuente, en esencia 
podemos tener una tabla en el portapapeles y pegarla como tabla 
en la ventana de Power pivot, esto en definitiva nos permite llevar 
datos desde practicamente cualquier aplicacion, como: 

■ Word 

■ Web 

■ Power Point 

Creepy Sources 

Nosotros llamamos a estas alternativas: Creepy Sources, fuentes 
pavorosas, dado que el origen de datos queda en la nada, es como 
si nos hubieramos sacado los datos debajo de la manga, y si alguien 
nos pide justificacion es dificil brindar 100% de confiabilidad. 
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Porque no tomar La tabla desde la aplicacion externa y copiar y 
pegarla en una hoja de Excel importarla si es posible, para 
posteriormente crear una tabla vinculada. 


jToma Nota! 



Independientemente de la aplicacion que sea: Microsoft Word, 
Acrobat Reader, Calc de Open Office, etc. Etc. La tabla de datos 
copiada al Portapales debe tener forma tabular obligatoriamente, es 
decir, organizada en filas y columnas de manera consistente, buenas 
etiquetas de columna, no totales ni subtotales y ausencia de filas o 
columnas en bianco. 


Ventajas y Desventajas de los Creepy Sources 

Los datos obtenidos de fuentes "alternas" brindan flexibilidad para 
obtener datos de lugares poco usuales o que de otra manera seria 
bastante complejo, pero es de esperar que tiene los mayores 
inconvenientes. 



Desventajas de los Creepy Sources 


Desventajas 

No cargar mas de mil filas con este metodo. 

No se pueden pegar columnas adicionales despues (Solo Calculadas). 
El formato tabular en otras aplicaciones puede ser enganoso. 

Poca documentacion y confiabilidad. 



Ventajas de los Creepy Sources 


Ventaja 

Se puede utilizar cualquier aplicacion. 

Pegar y Anexar, Pegar y Reemplazar (Filas NO Columnas) 
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Copiary Pegar 
Tabla 



Tabla de Microsoft Word 

Supongamos que queremos cargar La pequena tabla presentada a 
continuacion al modelo de datos de Excel. 


S T 0 T TAB LA_l_ibrosDel_a Col ec cion AD N. d ocx - Word ® 

9 Inicio InsertE Disenc Forma Ref ere Corres Revisa Vista Comp Q Indicar Miguel C... 


□ 


X 


Com parti r 


Peg. ^ 
Portapapeles 


| Gill Sans MT 

I 13 H 

N K S - abe x, x 1 


& - - A - Aa - 

K A 

Fuente 

Hi 




Estilos Ed i cion 


Parrafo Estilos 

. 1. I . 2 ■ i ■ 3 ■ i ■ 4 ■ i ■ 5 ■ i ■ 6 ■ i ■ 7 ■ i ■ 8 ■ i ■ 9 ■ i ■ ID- i - 11 - \ ■ 12 - i ■ O' i 14 i -IS- i ■ U6^17- i IB i 19 


Libra (ebook) 

Valor en Dobres 

El ADN de Power Pivot 

S 35.00 USD 

El ADN de Power View y Mapas 3D 

$ 18.00 USD 

El ADN de Power Bl (.com & Desktop) 

£ 25.00 USD 


0 _[ 


Pagina 1 de 1 35 palabras Q2 Espafiol [America latina) ^ 


- 


m h m - 



Figura 4. 21 - Tabla en Word 


Seleccionamos la tabla y pulsamos la combinacion de teclas Ctrl + 
C, despues vamos a la ventana de Power Pivot, pestana INICIO, 
grupo PORTAPALES, comando PEGAR. 


File 


Inicio 


Diseno 



Pegar 


™ Pegary anexar 
^ Pegar y reemplazar 
Eg Copiar 
Portapapeles 


Avanzadas 

a , 

De base De 
de datos T de 

Obt 


[DateKey] 

T 


A 

Date Key w 

Datelnt | 

Yea 


Figura 4. 22 - Comando Pegar habilitado 
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Una vez pulsamos die en el comando pegar, aparece un cuadro de Vista Previa 

dialogo con una vista previa y otras opciones para su configuracion. 

Una vez verificado todo, clic en Aceptar. 



Figura 4. 23 - Pegar Vista previa 


Si queremos anadir mas filas podemos copiarlas y utilizar el 
comando Pegar y Anexar, esto pega las filas adicionales en la parte 
inferior de la tabla previamente agregada. Por ejemplo, en la 
pequena tabla anterior hace falta agregar el libro: Tablas 
Dinamicas, La Quinta Dimension. 


Pegary 

Anexar 


0 *3 O 5 TABLA_LibrosDeLaColeccionADN.docx H — □ X 

lnici< Inser Disei Forrr Refei Com Revi< Vista Com Disei Pres< Q Indicar Miguel C.. ^ 
2 ^ i 2 4 6 £ 10 12 ii 14 i 1« 18 


El ADN de Power View y Mapas 3D 

$ 18.00 USD 

El ADN de Power Bl (.com & Desktop) 

S 25.00 USD 




I [Tablas Dinamicas La Quinta Dimension | $22.00 USD 
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Una vez puLsamos die en el boton pegar, el cuadro de dialogo vista 
previa aparece otra vez, mostrando los datos a pegar y la tabla 
donde seran anadidos debajo. 


Pegar vista previa ? X 

Obtenga una vista previa de los datos que va a anexar y comprjebe que la 
estruetura (incluso el ordem de columnas y la seleceion de tipos de datos) 
coincide con la de la tabla existente. 


Datos existentes en la tabla: 


Libro feb... 

Valor en Dolares 

El ADN de... 

$ 18.00 USD 

El ADN de... 

$ 25.00 USD 


Datos a pegar: 


Libro feb... 

Valor en Dolares 

Tablas Dina... 

$22.00 USD 

< 

> 


ED Excluir la primera fila de datos copiados. 


Aceptar 


Cane e la r 


Figura 4. 25 - Vista previa para anexar fHas 


Tambien podemos selecdonar toda la tabla nuevamente y pulsar 
clic encima del comando pegar y reemplazar. 


Libro (ebook) 

Valor en Dolares 

El ADN de Power Pivot 

$ 35.00 USD 

El ADN de Power View y Mapas 3D 

$ 18.00 USD 

El ADN de Power Bl (.com & Desktop) 

$ 25.00 USD 

Tablas Dinamicas La Quinta Dimension 

$22.00 USD 


Figura 4. 26 - Copiar y reemplazar toda la tabla 
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La vista previa aparece mostrando la tabla que sera reemplazada y 
la tabla que sera anadida en su lugar. 


Pegar vista previa ? X 

Va a sustituir los datos en la tabla existente. Obtenga una vista previa de los 
datos que va a pegar y compruebe que la estructura (incluso el orden de 
columnas y la seleccion de datos) coincide con los datos que va a sustituir. 


Datos existentes en la tabla: 


Libro (eb... 

Valor en Dolares 

A 

Libro (ebo... 

Valor en Dolares 


El ADN de ... 

$ 35.00 USD 

V 

Datos a pegar: 

Libro (eb... 

Valor en Dolares 

A 

Libro (ebo... 

Valor en Dolares 


El ADN de ... 

$ 35.00 USD 


El ADN de ... 

$ 18.00 USD 

V 


□ Excluir la primera fila de datos copiados. 


Aceptar 


Cancelar 


Figura 4. 27 . Vista previa para reempiazar 


EL Siguiente Paso 

En el siguiente capitulo estudiaremos el modelo de datos, como 
vincular las tablas agregadas a este, para manipular sus campos de 
manera conjunta, ademas, daremos las primeras pinceladas de los 
dos tipos de calculos personalizados: Columnas Calculadas y 
Medidas. 




Vista Previa 


NOTA 

Elimine del modelo de 
datos esta tabla, ya que 
solamente sirve como 
ilustracion para obtener 
datos del Portapales y no 
tienen ningun objetivo en 
el resto del libro, ten en 
cuenta que agregar tablas 
con el portapapeles no es 
recomendable. 
























La Presente Pagina se ha dejado en Blanco de forma deliberada. 
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Entretejiendo Tablas: El Modelo de Datos 
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NOTA 

Cuando estes explorando 
las columnas individuales 
es vital tener presente que 
tipo de dato contiene: 
Texto, numero, fecha o 
booleano, ya que 
posteriormente esto debe 
coincidir en la ventana de 
Power Pivot. 

Otro aspecto a considerar 
cuando nos estamos 
familiarizando con las 
tablas, es que esten 
optimas para utilizar en el 
modelo de datos, es decir, 
que tengan el formato 
tabular. 

El analisis exploratorio de 
tablas es especialmente 
importante para conocer 
aquellas bases de datos 
de terceros o a las cuales 
tenemos acceso por 
primera vez. 


Analisis Exploratorio de Tablas 

En el capitulo anterior agregamos tablas de distintos origenes, pero 
para poder trabajar con todas estas tablas es necesario "volvernos 
intimos de ellas", empaparnos con la informacion que tienen. 

El analisis exploratorio de tablas no es otra cosa que tomar una 
pausa activa antes de arrancar, incluso antes de agregar los datos 
al modelo de datos y conocer a profundidad que contienen, pues 
una fase de conocimiento obligatoria cuyo objetivo nos permitira 
hacer analisis mas eficaz y encontrar anomalias o desfases. 

En el capitulo previo agregamos las tablas desde: Excel, Vinculada, 
Access y Azure Marketplace; sin embargo, para propositos de esta 
primera seccion en el capitulo, se deja un archivo con todas las 
tablas en diferentes hojas de Excel (Ninguna anadida al modelo de 
datos). 
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Tabla Pedidos 

Para nuestro escenario tenemos cuatro tablas hasta el momento. 
La primera de ellas, es la tabla Pedidos, comencemos a describirla 
para conocer sus datos. 


B *5 * c* - = Capftulo 05 (Inicial) - Pt 1.xlsx - Excel Herr... 


S Inicio Insertar Diseno de 

Formulas Datos Revisar Vista Desarrolla< Power Pivi 

Diseno Q Indicar 

Miguel G.. 

Com parti r 


1 C29 -I : 1 

f* Normal 







/ B 

D E 

F 

G 

H 



Numero de Tipo de 

SKU Categona de 

Precio de Venta 

Unidades 

Costo del Producto Cost! 

u 

2 

Pedido |"^"| Compra 

[V] |"^~| Descuento 

0 (€0.00) Q 

(tk 1-D igit) g 

(€ 0.00) 

_0_ 


3 

98069372 Normal 

CCOI 

105.06 

2 


8 


4 

98069373 Normal 

L02 Cyber Monday 

96.48 

3 


9 


5 

98069374 Normal 

CB0I 

444.06 

2 


6 


6 

98069375 Normal 

CCOI Non 

105.06 

2 


6 


7 

98069376 Normal 

CI2 

29.84 

1 


8 


8 

98069377 Devoludon 

L07 Non 

37.89 

1 


5 


9 

98069378 Normal 

L02 

120.60 

3 


9 


10 

98069379 Normal 

L07 Non 

37.89 

1 


7 


II 

98069380 Normal 

LOI 

61.50 

2 


7 


12 

98069381 Normal 

L02 

80.40 

2 


9 

- 


► TABLA.Pedidos 

]| TABLA_SKUProducto(s) 

| IQUJ ... © : d 

J 

H 

s 


Figura 5.2- Tabla Pedidos 


Lo primero es dar un vistazo cada campo y comprender que 
finalidad tienen, a continuacion, se lista y justifica cada campo de 
la tabla pedidos. 


Descripcion de 
Campos 


■ Numero de Pedidos: Este campo contiene el numero de 
venta o transaccion, el cual es numero unico que no se 
repite. 


■ Tipo de Compra: En este campo se coloca a cual de las 
siguientes categories corresponds la compra: Normal o 
Devolucidn. 



SKU: Es el identificador que se utiliza para un producto o conjunto 
de productos especificos, en la tabla indica cual o cuales 
productos se compraron. FOREIGN KEY Ver Nota mas adelante. 

4SSBb ^ 
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NOTA: jlmportante! 

Tengamos en cuenta que 
el campo Precio de Venta 
en realidad representa los 
ingresos (Unidades por 
Precio de Venta Unitario). 
En la mayor parte se 
utilizara el nombre Precio 
de Venta, sin embargo, no 
olvides que son los 
ingresos. 


Otra Razon para hacer 
analisis exploratorio de 
tablas, es que nos permite 
identificar nombres de 
campos enganosos y 
darles la interpretacion 
adecuada, esta es una 
situacion mas comun de lo 
que pude parecer. 


Categoria de Descuento: Existen diferentes promociones 
para fechas especiales, este campo indica a cual de estas 
promociones aplico La compra: Cyber Monday, Black Fraday, 
Day Off Full o Special Day; si la compra no aplico a ninguna 
promocion, entonces en la tabla aparece Non. 


Precio de Venta: Indica el precio unitario de venta por las 
unidades vendidas (En Realidad INGRESOS). 


Unidades: Indica cuantas unidades de dichos productos se 
compraron. 


Costo del Producto: Indica el valor en euros que tuvo la 
produccion de dicho producto. 


Costo de Envio: Senala el valor en euros que tuvo el 
transportar el producto desde el almacen al destino del 
cliente. 


Costo de Empaque: Senala el valor en euros que tuvo el 
empaque apropiado para el producto, lo que asegura que 
llegara en condiciones optimas al cliente. 


Fecha de Envio: Fecha en la cual salio el producto al destino 
del cliente, tambien corresponde a la fecha de compra. 


Fecha de Llegada: Fecha en el cual el cliente obtiene su 
compra en Las manos. 


Pals: Donde se encuentra el cliente. 


■ Ciudad: Destino donde se encuentra el cliente y se entrega 
el producto. 


Informacion 
Basica General 


Sabemos entonces que la tabla pedido tiene 13 campos (Columnas) 
y 24891 registros (Filas) en un formato tabular optimo, ademas 



sabemos que la fuente esta en Access y se actualiza diariamente. 


iMTr< 


El ADN DE Power Pivot 


Tabla SKU Producto(s) 

Esta tabla cuenta con tan solo dos campos. 


■ SKU: Identificador que se utiliza para un producto o 
conjunto de productos, en esta tabla solamente esta listado 
cada SKU una unica vez. PRIMARY KEY Ver nota mas delante 

■ Producto(s): Indica cual producto o productos estan 
asociados con el codigo SKU, algunos ejemplos: Libro de 
Calculo, CD de Mozart, etc. 

Se sabe entonces que la tabla SKU Productos tiene 2 campos 
(CoLumnas) y 38 registros (Filas), adicionalmente sabemos que 
tiene como proposito listar los SKU e indicar a que productos 
corresponde, esto es importante por lo que categorizamos a esta 
tabla como Tabla de Busqueda, mas adelante quedara mas claro. 

Tabla Categoria de Productos 

Esta tabla cuenta con tres campos. 


■ SKU: Es el identificador que se utiliza para un producto o 
conjunto de productos, en esta tabla solamente esta listado 
cada SKU una unica vez. PRIMARY KEY Ver nota mas delante 

■ Categoria de Producto: Aqui se indica a que categoria 
general pertenece el producto, por ejemplo, un libro de 
calculo pertenece a la categoria libros. 


■ Precio de Venta: Indica el valor en euros del producto 


Se sabe entonces que la tabla Categoria de Producto tiene 3 campos 





y 38 registros, tiene como proposito categorizar los productos. 





Descripcion de 
Campos 


Informacion 
Basica General 


Descripcion de 
Campos 


Informacion 


Basica General 
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Tabla Descuentos 

Una diminuta tabla de dos campos. 


Descripcion de 
Campos 


Informacion 
Basica General 


■ Descuento: Indica el porcentaje que se debe restar del 
precio para el descuento. 


■ Categoria de Descuento: Indica a cual dia de promocion 
corresponde. ^ jANOMAUA!: el elemento BLACK FRIDAY 
esta mal escrito, aparece como: BLACK FRADAY - jTener en 
Cuenta de ahora en adelante para su manipulation! 


Sabemos entonces que la tabla Descuentos tiene 2 campos 
(Columnas) y 5 registros (Filas) en un formato tabular optimo. 


NOTA 

No es necesario, hacer las 
descripciones y tablas que 
se han presentado hasta el 
momenta, mucho menos 
cuando tenemos un 
numero considerable de 
ellas, lo importante en 
cambio, es conocer y 
explorar las tablas y 
campos para poder 
trabajar y analizar con 
total libertad. 


Resumen Analisis Exploratorio 

Observemos la informacion esencial en el resumen presentado en 
la tabla siguiente. 

^ Tabla Resumen de Analisis Exploratorio 


Tabla 

Registros 

Campos 

Tipo 

Optima 

Pedidos 

24891 

13 

TM 


SKU Prod. 

2 

38 

TB 


Categorias 

3 

38 

TB 

S 

Descuentos 

2 

5 

TB 



TM: Significa que es una tabla base o matriz y TB: una tabla de 
busqueda, mas adelante clarificaremos estos terminos. La columna 
optima senala si la tabla tiene formato tabular o no. 


Ya conocimos las tablas, es momento de "entretejerlas" y 


divertirnos un poco con ellas. 
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Entretejer Tablas a la Antigua 

Dadas las tablas anteriores, que pasaria si nos solicitaran: Realizar Enunciado 

un reporte donde veamos los ingresos generados por cada 

producto, de acuerdo a cada categorfa y, adicionalmente, poder 

filtrar por los distintos porcentajes de descuento. iEs esto una tarea 

facil de hacer? Dado que necesitamos el campo Producto(s) de la 

tabla SKU Productos en el area de filas, el campo Categorfa de 

Producto de la tabla Categorfa de Productos en el area de columnas, 

el campo precio de la tabla pedfdos en el area de valores y 

finalmente, el campo Categorfa de descuento de la tabla descuento 

bien sea en el area de filtro o en un Slicer. iComo realfzar este 

reporte? - ijAlgo de Alqufmia Talvez!? 


Relacionar Tablas con BUSCARV y sus Secuaces 


Averiguemos como ejecutar la solicitud anterior a la antigua, con 
formulas, lo cual es el metodo mas utilizado hoy dia por los 
usuarios despues de la revolucion que supuso el modelo de datos. NOTA 


Del ano 2009 hacia atras no habia manera de integrar las tablas, lo 
que debiamos hacer, era crear una nueva tabla que unificara los 
datos de los diferentes origenes, por esto creamos una copia de la 
hoja con la tabla pedidos y la renombramos como: 
TABLAJJNIFICADA, la razon para esto es que la tabla pedidos tiene 
todas las transacciones mientras que la demas tablas contienen 
datos especificos, si lo miramos desde el punto de vista de la 
funcion BUSCARV, la tabla Pedfdos es donde se inserta la funcion, 
la tabla a "llenar", y las demas son las tablas de busqueda que se 


No es del todo cierto que 
no contabamos con una 
opcion para integrar 
multiples tablas, pues 
tenfamos y tenemos aun la 
alternativa de rangos de 
consolidation multiple, 
pero esto es tanto 
restrictivo como olvidado, 
su utilizacion cae 
exponencialmente a lo 
largo de los anos. 
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Analizamos un poco mas La tabLa pedidos y eL enunciado. 


En los campos de esta tabla 
no hay ninguna con el 
nombre del producto, 
solamente el identificador 
que es el SKU. Es dificil leer 
letras o codigo, por ejemplo: 
CBOI, por lo que es mejor el 
nombre del producto, estos 
datos estan en otra tabla que 
tiene la equivalencia entre 
SKU y el nombre del 
producto. 


Numero de Tipo de 

Pedido ["^ ] Compra 

SKU 

0 • 

Categoria de 

Descuento [V] 

Precio de Venta 
(€0.00) ^ 

Unidades 

(tt: 1-Digit) p^~| 

Costo del Producto 

(€0.00) ^ 

Costo di 

(€0. 

98069372 

Normal 

/fCOI 

Non 

105.06 

2 


8 


98069373 

Normal 

/ L02 

Cyber Monday 

96.48 

3 


9 


98069374 

Normal '/ 

CBOI 


444.06 

2 


6 


98069375 

/ 

CCOI 

Non 

105.06 

2 


6 


98069376 

/formal 

02 


29.84 

1 


8 


98069yn 

Devoludon 

L07 


37.89 

1 


5 


9877(69378 


L02 

Non 

120.60 

3 


9 


/98069379 

Normal 

L07 

Non 

37.89 

1 


7 


/ 98069380 

Normal 

LOI 


61.50 

2 


7 


98069381 

Normal 

L02 

Non 

80.40 

2 


9 


98069382 


CBOI 

Non 

666.09 

3 


6 


98069383 


L02 

Non 

80.40 

2 


5 


98069384 

Normal 

B05 


50.65 

1 


10 


98069385 

Normal 

L07 


37.89 

1 


8 


98069386 

Devoludon 

LOI 

Non 

92.25 

3 


6 


98069387 


B05 


151.95 

3 


7 



Figura 5.3- Tabla Pedidos 


Primera Parte 
del Enundado 


Nos solicitan realizar un reporte donde veamos los ingresos 
generadospor cadaproducto: Los ingresos Los podemos obtener con 
La coLumna Precio de Venta de la tabla Pedidos, visto que dicho 
campo guarda el precio de la venta multiplicado por Las unidades, 
osea los ingresos. Por otra parte, los nombres de los productos no 
se encuentran la tabla pedidos puesto que se identifican con eL 
SKU, la tabla que tiene una equivalencia entre SKU y el nombre del 
producto es la tabla denominada SKU Productos, por lo que para 
abordar este problema debemos crear una columna auxiliar en la 
tabla pedidos y traer los nombres aqui, esto lo realizamos con la 
funcion BUSCARV. En la construccion a estas columnas auxiliaries 
le hemos asignado un color de fondo diferente para asi tener una 
guia visual de cuales fueron columnas construidas para apoyar la 
tabla base o matriz, vease la figura a continuacion. 
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El siguiente esquema se detalla la relacion creada entre la tabla 
Pedidos y la tabla SKU Productos mediante la funcion BUSCARV, 
esto con el objetivo de crear una representacion visual. 



Tabla Pedidos | Tabla Matriz o Base 

Figura 5. 4 - /lustration de la creation mediante BUSCARV de las tablas pedidos y SKU Productos 


Siguiendo el enunciado, despues nos dice que: de acuerdo a cada 
categoria, adicionalmente poderfiltrar por los distintos porcentajes 
de descuento. Como el lector ya puede inferir inminentemente; 
como la categoria de producto no se encuentra en la tabla pedidos 
se debe relacionar con la tabla Categoria de Productos dado que 
esta contiene el dato de la categoria de acuerdo a el SKU. 


Segunda Parte 
del Enunciado 
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Por lo que crear la relacion con la funcion BUSCARV es casi gemela 
con la anterior, lo unico que varia es la tabla de busqueda. 


En paralelo tambien puedes ver que el porcentaje de descuento 
sigue la misma dinamica, porque dicho porcentaje no se encuentra 
en la tabla pedidos sino en la tabla descuento; en esta ocasion, la 
formula cambia un poco debido a que el valor de busqueda no esta 
en la primera columna, sino en la segunda, a la izquierda, por lo que 
debemos a acudir los "secuaces'' de BUSCARV para llenar la tabla 
pedidos. 


Nota como la funcion en esta relacion cambia, pues como tiene una configuracion diferente 
el formato de busqueda se deben utilizar los secuaces INDICE y COINCIDIR de BUSCARV. 


SKU p7| Praducta(s) 


LO I 

LG2 

LQ3 

L04 

i nc 


Calculus For Dummies - Nark 


Calculus, 7th Ed 


ition - Jam es 


Calculus - Ron Larson 


Descuento 

-«-E- 


Categona de 
Descuento ^ 


-0 


Calculus and Analytic Geometry - George B 

B. I | n iimrrih, PUrirr \/«l I 

Tabla SKU Producto(s) \ Tabla 
de Busqueda 


SKU Categona de Precio de Venta 



|Vj Producto(s)^ 

(4 0.00) g 

L0I 

Libro 

30.75 

L02 

Libro 

40.20 

L03 

Libro 

29.99 

1 04 

1 ihrn 

30 10 


0.25 Balck Fraday 
0.20 Cyber Monday 
0.35 Special Day 
0.15 Day Off Full 
0.00 Non 

Tabla 

Descuentos \ 

Tabla de 
Busqueda 


Tabla Categona de Productos | 


IMDICE(De5cuento5[De5cuento 
(%)]; CO IN CIDI R([@ [Gatego iTa de 
De5cuento]];De5cuento5[Categoria dej 
Descuentoj;0)_) 


Tabla de Busqueda 


0 


SKU Categona de 


Producto(s) 


Categona de 


Porcentaje de 


Descuento 

a a 


Producto 


Descuento 


CC0I Non 

Sabaton: Heroes + Sabaton: Coar Arms + Sabaton: Caralus Rex 

Co 

b*bo - - 


■1 

LG2 Cyber Monday 

Calculus, 7th Edition - James 

Libro' 



0,2* 

CBOI 

Batman Begins + The Dark Knight + The Dark Knight Rises 

Combo 



0 

CC0I 

Sabaton: Heroes + Sabaton: Coar Arms + Sabaton: Caralus Rex 

Combo 



0 

/-• 1 'k 

1 /-■ II 







Tabla Pedidos | Tabla Matriz o Base 






































El ADN DE Power Pivot 



Con Las reLaciones creadas mediante la funcion BUSCARV ya 
podemos construir el reporte de tabla dinamica solicitado. 



Suma de Precio de Venta 

Etiquetas de columna Q 



Etiquetas de fila 

Q Blue-Ray CD 

Combo 

Libro 


50 Must-Have Beethoven Masterpieces 
Batman Begins 

Batman Begins + The Dark Knight + The Dark Knight Rises 
Beethoven: Complete Symphonies 
Calculus - Ron Larson 

Calculus and Analytic Geometry - George B 

Calculus For Dummies - Mark 

Calculus, 7th Edition - James 

Cocktail Party Jazz 

Green Hill Jazz Sampler 

Inception 

Interstelar 

Jazz Collection 

Men of Steel 

Physics for Scientists and Engineers - Serway 

Sabaton: Heroes + Sabaton: Coar Arms + Sabaton: Caralus Rex 

Sabaton: The Art of War + Sabaton: Primo Victoria 

Sears & Zemansky's University Physics, Vol. I 

Sears & Zemansky's University Physics, Vol. 2 

The Dark Knight 

The Dark Knight Rises 


$19,387 

$45,486 

$1,885,901 

$28,658 

$78,914 

$53,646 

$106,404 

$171,819 

$18,755 

$17,284 

$24,044 

$44,571 

$13,765 

$30,156 

$103,313 

$313,914 

$109,568 

$143,427 

$55,013 

$26,486 

$30,375 


Figura 5.6- Reporte de Tabla Dinamica Solicitado 


NOTA 

Creamos la tabla dinamica 
de la manera clasica, es 
decir, dejamos la celda 
activa dentro de la tabla 
unificada y vamos a la 
pestana INSERTAR y 
pulsamos clic encima del 
comando TABLA 

DINAMICA, 
posteriormente 
procedemos a colocar los 
campos necesarios en las 
areas de colocacion, asf: 

Columnas: Categorfa 

Filas: Producto(s) 

Valores: Precio de Venta 

Filtro: Ninguno 

Slicer: Descuento(%) 


Obstaculos de Relacion de Tablas a la Antigua 

Una vez se domina como relacionar tablas de este modo, que por 
cierto no es para nada dificil, cambiar o encontrar desventajas 
puede ser algo complejo y mas que eso una costumbre dificil de 
dejar, no obstante, relacionar tablas con BUSCARV y sus secuaces 
tienen serios inconvenientes que es sustancialtenerlos presentes. 
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Lista de Obstaculos. 


■ La hoja de calculo se empieza a poner cada vez mas Lenta 
mientras mas datos tenga y mas reladones deba manejar, a 
partir de unos 10 mil registros se puede empezar a notar el 
descenso en el rendimiento de Excel (Oue sucede si tenemos 
cientos de miles defilas? 


■ i.Que sucede si necesitamos bases de otras fuentes que 
contengan millones de datos, no es posible por este 
metodo? 


■ Si el numero de relaciones y tablas es elevado este metodo 
es tedioso e incluso dificil de entender y ejecutar. 


■ Todas las relaciones trabajan con funciones, todo esto de 
manera textual, pero si contaramos con una representacion 
y funcionalidades graficas seria un trabajo mas ameno. 
Vease la figura 5.4 y 5.5 que son ilustraciones creadas para 
el presente texto que nos ayudan a entender de una forma 
sencilla las relaciones entre tablas. 

■ Integrar datos desde otras fuentes, como Access, Azure 
Marketplace y relacionar con este metodo es complicado. 

Terminologfa Derivada 

De la seccion anterior podemos sacar terminos que nos ayudaran 
de ahora en adelante. 


■ Tabla Base o Matriz: Es La tabla que generalmente tiene 
mayor densidad de datos y en la cual utilizamos BUSCARV o 
algunos de sus secuaces para "llenarla". 


■ Tabla de Busqueda: Es la tabla o tablas donde buscamos los 
valores con los cuales se debe llenar tablas base. 





Relacion: La manera en que se vinculan tablas diversas. 
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Entretejer Tablas con el Modelo de Datos 

jTodos los obstaculos han sido subsanados! El modelo de datos en 
Excel es el "nirvana", una especie de estado ultimo para desarrollar 
relaciones con un par de clics y de facil intuicion, realizar calculos 
mas alia de lo sonado dada la integracion de datos de multiples 
fuentes. Resulta que todos los obstaculos mencionados 
anteriormente han sido removidos, en cambio de ello, nos han 
traido una funcionalidad descomunal, ahora vamos a ver una 
infima parte de ella con relaciones en el modelo de datos, a lo largo 
de libro descubriremos mas y mas. 


Relacionar con Vista de Diagrama 

Para esta segunda seccion es tiempo de volver al archivo de Excel 
como lo dejamos en el capitulo anterior. Por lo que hemos venido 
hablando en este capitulo ahora entendemos el concepto de 
relacion, todo lo previo aplica en el modelo de datos, entonces, 
vamos a la ventana POWER PIVOTy en la pestana INICIO, grupo VER 
pulsamos clic en el boton VISTA DE DIAGRAMA. 


-\ 


H 

2 Autosuma ^ 

J CrearKPI 

P 

Ef 

F : Ip 

Buscar 


Vista de 

Vista de 

Mostrar Area de 



datos 

diagrama 

J 

oculto calculo 

Buscar 

Calculos 


Ver 


Figura 5. 7 - Comando paro la Vista de Diagrama 


NOTA 

En Este punto la tabla 
descuentos no esta 
agregada al modelo de 
datos, asegurate de 
cargarla antes de seguir 
en el capitulo, esta tabla 
esta en una hoja del 
archivo de Excel. 


jY VOILA! LA REPRESENTACION GRAFICA DE LA OUE VENIAMOS 
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Observa con detenimiento la figura siguiente, como cada cuadro 
bianco "personifica" una tabla en el modelo de datos y a su vez, 
exhibe cada columna que contiene. 


NOTA 

Las representaciones de 
las tablas en la vista de 
diagrama se pueden 
mover con toda libertad a 
lo largo y ancho del area, 
redimensionar su tamano 
para leer mejor los 
nombres de los campos, e 
incluso maximizar si 
deseas tener una vision 
mas amplia de una tabla 
en especffico. 


Inicio 


Diseno 


6 3 

Pegai 


Pegary anexar 
Pegary reemplazar 
Eg Copiar 
Portapapeles 


a 


^ Q- & Gs 

De base De servicio De otros Conexiones Adualizar 
de datos ” de datos '■ ori'genes existentes 

Obtener datos externos 


Q Tipo de datos: 
Formato: - 

Tabla 

dinamica’ $ ^ % ? 


0 TABLA_Pedidos MM 

0 Numero de Pedido 
0 Tipo de Compra 

0 sku 

0 Categorfa de Descuento 
IS Precio de Venta 

□ Unidades 

0 Costo del Producto 
IS Costo de Envio 

□ Costo Empaque 
IS Fecha de Envio 
IS Fecha de Llegada 

□ Pafs 

IS Ciudad 


0 SKU Productos 

0 sku 

0 Producto(s) 


0 TABLA_CategorfaDeProductos 

0 sku 

0 Categorfa 
0 Precio de Venta 


0 Descuentos 
0 Descuento (%) 

0 Categorfa de D... 


0 BasicCalendarEnglish 
0 DateKey 
0 Datelnt 
0 YearKey 
0 QuarterOfYear 
0 MonthOfYear 
0 DayOfMonth 
0 MonthName 
0 MonthlnCalendar 
0 QuarterlnCalendar 
0 DayOfWeekName 
0 DaylnWeek 



Figura 5.8- Tablas en la Vista de Diagrama 


Cada uno de los cuadritos es una tabla, de hecho, podemos ver su 
nombre en la parte superior de color verde, en el cuerpo de la 
representacion grafica de la tabla podemos apreciar cada uno de 
sus "hijos": los campos. Ahora en vez de utilizar la funcion BUSCARV 
lo unico que debemos hacer para relacionar las tablas es identificar 
la tabla basey las tablas de busqueda. Vamos a tomar la primera, que 
consiste en relacionar la tabla Pedidos con la tabla SKU productos. 
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Lo unico que debemos hacer es posicionar el cursor de nuestro 
mouse encima del nombre del campo que es equivalente en la 
tabla de busqueda SKU Productos, pulsar clic y manteniendolo de 
este modo llevar la linea que aparece a el campo equivalente en la 
tabla base Pedidos, en este caso es bastante sencillo porque en 
ambas tablas se llama SKU. 


Relacionar 

Tablas 



Pausemos un Momento 

Tomate un momento para refiexionar acerca de las relaciones con 
BUSCARV y el Modelo de Datos, es exactamente igual, solo que con 
Power Pivot es mucho mas sencillo y armonico, igualmente conociendo 
los conceptos de tablas base y de busqueda esperamos que no tengas 
dificultades en realizar las demas relaciones y comparar tu resultado 
con la figura siguiente, asl evaluas tu comprension. 


0 TABLA_Cate... 

0 Descuentos 

0 SKU Productos 


0 SKU 

0 Descuento (%) 

0 SKU 

/s 

0 Categorfa 

0 Precio de Venta 

0 Categorfa de Descuento 

0 Producto(s) 

- 


* * 

0 TABLA_Pedidos 
0 Numero de Pedido 
ES] Tipo de Compra 

0 sku 

CD Categorfa de Descuento 

EH Precio de Venta 

EH Unidades 

ES] Costo del Producto 

EH Costo de Envio 

ES ] Costo Empaque 

EH Fecha de Envio 

EH Fecha de Llegada 

EH Pafs 

EH Ciudad 


NOTA 

Observa como incluso las 
flechas tambien aparecen, 
indicando que tabla 
"llenar", en este caso las 
tablas de busqueda 
senalan o apuntan a la 
tabla base tal cual como lo 
hicimos en nuestra 
ilustracion representativa 
en la seccion anterior. 


Figura 5.9- Todas las Tablas Vinculadas en la Vista de Diagrama 
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Reladonar 

Tablas 


La tabla de calendario no se muestra en la figura anterior dado que 
no esta relacionada con ninguna otra hasta el momento, sin 
embargo, sigue estando en la interfaz solo que se recorto para 
presentar solo las directamente involucradas. 


jToma Nota! 



La direction de las flechas para las versiones de Power Pivot de Office 
2010y 2013 apuntan en la direction contraria, es decir, desde la tabla 
base hacia la tabla de busqueda, esto porque es la convention en 
bases de datos relacionales, pern para nuestra imagen mental la 
direction de las flechas en Power Pivot 2016 la cual sugiere que las 
tablas de busqueda Henan las tablas bases se ajusta perfectamente. 


NOTA 


jASI DE EACH, jAS'l DE RAPIDO, UN PAR DECLICS Y ESTA HECHO! Ahora 
pasemos a realizar el reporte de tablas dinamica solicitado 
nuevamente. Vamos a la pestana INSERTAR en la ventana de Excel 
y pulsamos clic en el boton TABLA DINAMICA, alii seleccionamos 
USAR EL MODELO DE DATOS DE ESTE LIBRO. 


Para Power Pivot en Office 
2010 y 2013 se debe crear 
la tabla dinamica desde el 
comando tablas 

dinamicas en la venta 
Power Pivot, la opcion 
usar el modelo de datos 
de este libro que aparece 
cuando se pulsa clic en el 
comando de la pestana 
insertar es nueva para 
Office 2016. 


Crear tabla dinamica 

? X 

Seleccione los datos que desea analizar 

O Seleccione una tabla o rango 


Tabla o rango;: 

m 

O Utilice una fuente de datos externa 

Nombre de conexion: 


[® Usar el modelo de datos de este libro 


Elija donde desea colocar el informe de tabla dinamica 

O Nueva hoja de calculo 
(*)|Hoja de calculo existente! 


Ubicacion: DescuentolSGSIO 

l£ 

Elige si quieres analizar varias tablas 

Agregar estos datos al Modelo de datos 


Aceptar 

Cancelar 
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Prestale especial atencion al panel de campos. 


Panel de Campos 


Saca ventaja 
de las 

caractensticas 
mas recientes 
en tablas 
dinamica para 
Excel 2016, 
con el cuadro 
de busqueda 
podemos 
encontrar el 
campo 
deseado 
velozmente. 


Campos de tabla dinamica 

ACTIVO TO DOS 

Seleccionar campos para agregar al informe: 


▼ X 




La tabla calendario que fue cargada desde 
Azure Marketplace se encuentra separada 
debido a que no esta relacionada con 
ninguna tabla a pesar de estar en el 
modelo de datos. 


>r 8 BasicCalendarEnglish 
H Descuentos 
SKU Productos 

>F 8 T AB L A_C ateg o n'a D eP ro d u cto s 

> E£gTABLA_Pedidos 

> B Pedidos 

Arrastrar campos entre las areas sit 
T FILTR05 llll COLUMNS 


Vease como todas las tablas que se 
relacionaron en la vista de diagrama 
aparecen aqui agrupadas en el panel 
de campos. 



= FILAS 


Esta tabla no esta agregada al modelo 
de datos, el icono en forma de tabla al 
extremo izquierdo no tiene la 
"cabecera rellena" indicando que no 
esta en Power Pivot, esta tabla pedidos 
es la que se encuentra en la hoja de 
Excel y se desvinculo de Power Pivot ya 
que se decidio conectar dicha tabla 
directamente a su fuente de Access. 


£ VALORES 


Figura 5.11- Aspecto del Panel de Campos con el Modelo de Datos 


Utilizando el icono en forma de triangulo en todo el extremo derecho de 
cada tabla podemos desplegar cada uno de los campos de la misma, 
ahora asignemos los campos a las areas de colocacion como se hizo con 
el reporte de tabla dinamica relacionado con BUSCARV, solo que ahora 
se hace directamente de desde cada una de las tablas. La tabla dinamica 


Asignar 
Campos a 
Areas 


es exactamente la misma que la presentada en la figura 5.6. 
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Diferenda entre 
ambos metodos 


La diferenda entre el metodo con BUSCARV y el del modelo de 
datos, es que el primero es una operacion y el segundo una 
declaracion (la ultima no crea formulas, esto lo hace mas rapido). 


Tipos de Relaciones 

Hasta el momento de lo que va del capitulo solo hemos visto un 
tipo de relacion: Uno a Muchos, no obstante, existen dos tipos mas 
que son fundamentales conocer. 


NOTA 

Primary Key & Foreign Key 

La columna (Campo) que 
tiene los elementos que 
son unicos, es decir, la 
columna que se encuentra 
en la tabla de busqueda, 
se llama: calve principal o 
Primary key. 

Por otra parte, a la 
columna que contiene los 
elementos que se repiten, 
es decir, la columna que 
se encuentra en la tabla 
base se le llama: clave 
externa o foreign key 


Uno a Muchos: Este es basicamente el tipo de relacion que hemos 
venido tratando, consiste en relacionar una tabla mediante una 
columna equivalente, es decir, las columnas que coindicen en las 
dos tablas, pero en una, los elementos de la columna estan listados 
una vez, son unicos como en el caso del campo SKU de la tabla SKU 
Productos, y en la otra tabla se repiten estos elementos como el 
campo SKU en la tabla pedidos, en Power pivot de Excel 2016 la 
flecha apunta al campo que tiene los elementos repetidos. 

Uno a Uno: Este tipo de relaciona dos columnas identicas, las cuales 
no repiten sus elementos, la relacion uno a uno es muy poco 
frecuente, sin embargo, la ocasion que se necesite hacer este tipo 
de relacion ten en mente que no es problema realizarla en Power 
Pivot, ya que toma "cualquiera" como tabla base y la otra como 
tabla de busqueda. 


Muchos a Muchos: Este tipo de relacion une dos columnas foreign 
key, un elemento en la columna A esta relacionado con varios en la 
columna B, pero un elemento en la columna B puede estar 
relacionado con varios elementos en la columna A. 


El ADN DE Power Pivot 



jToma Nota! 



El Modelo de Datos en Excel no soporta relaciones Muchos a Muchos, 
eso es triste lo se, pern por lo menos con la intervenclon de formulas 
DAX o con la ayuda de funcionalidades alternatives lo podemos 
conseguir. 


Relacionar Muchos a Muchos con Power Query 

Por ahora veremos una alternativa sencilla para trabajar con un tipo 
de relacion muchos a muchos en el modelo de datos, la clave aqui 
sera trabajar con Power Query, tambien para esta situacion 
tomaremos un par de tablas alternas a las que hemos venido 
trabajando hasta el momento en eltexto. 







Esta tabla contiene el 

No mfare g 

Monica 

Medio g 

On-Line 

Ales 

Enero 

g Ale die 

Regofo |V!_4 

1,000.00 € 

nombre del vendedor y 
que medios se le han 
asignado para realizar 

sus ventas. 

Monica 

Off-Line 

Enero 

Off-Line 

500.00 € 

Nicolas 

Off-Line 

Enero 

Afiliado 

600.00 € 


Nicolas 

Afiliado 

Febrero 

On-Line 

875.00 € 


Marta 

On-Line 

Febrero 

Off-Line 

720.00 € 

Esta tabla indica el monto 

Marta 

Afiliado 

Febrero 

Afiliado 

650.00 € 

que tiene para dar como 

Diego 

Off-Line 

j 

Marzo 

On-Line 

900.00 € 

regalo cada medio de 



Marzo 

Off-Line 

920.00 € 

venta en los primeros 
cuatro meses del ano 



Marzo 

Afiliado 

940.00 € 


Abril 

On-Line 

200.00 € 

Abril 

Off-Line 

250.00 € 

Abril 

Afiliado 

210 '.OO € 


Figura 5.12 - Tablas para Ejemplo de relacion Muchos a Muchos con Power Query 
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Pregunta 

Planteada 


Supongamos que se desea ver en una matriz que monto tiene 
asignado cada comerdal, es un ejemplo sencillo, pero lo que 
queremos lograr con esto es captar La esencia del problema. 

Como se puede ver en las tablas, las columnas equivalentes son 
Medios para cada uno, no obstante, y esto es lo clave, en ambas 
tablas, los elementos del campo medio se repiten, dicho de otro 
modo, en las dos tablas el campo medio es una clave externa. Si 
agregamos las tablas a Power Pivot y tratamos de relacionar las 
columnas Medios, entonces saldra un error. 


Power Pivot para Excel 


X 


O No se puede crear I a rel scion pa rq Lie cada coluri na contiene va I o res d up I i cad o s, Seleccio ne a I m enos una co I um na q ue 
contenga solamentevalores uni cos. 


Aceptar 


Figura 5.13 - Error al trator de hacer uno relacion Muchos o Muchos 


Nueva Tabla 
Unificada 


NOTA 


En lugar de relacionar las dos tablas, vamos a crear una nueva tabla 
unificada con ayuda de Power Query, para esto dejamos la celda 
activa dentro de La primera tabla y vamos a La pestana DATOS, grupo 
OBTENER Y TRANFORMAR y pulsamos clic en el comando DESDE 
UNA TABLA. 


Recuerde que Power 

Este comando nos 


Query en Office 2016 es el 

permite agregar a 

Formulas Datos Revisa r 

grupo Obtener y 

Power Query tablas 

Mostrar consultas 

transformar, si utiliza la 

desde Excel. 

^ Desde una tabla 1 
consults - L© Fuentes recientes 

version 2013 o 2010 acuda 


la pestana POWER QUERY 


despues de habilitarla en 


Obtener y transformar 


COmplementOS COM. Figura 5. 14 - Comando Desde una Tabla en Power Query 
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Con la accion anterior, el editor de Power Query aparece con la 
tabla ya cargada en su interfaz, aqui no vamos a realizar nada 
solamente vamos a la opcion CERRAR Y CARGAR para finalmente 
pulsar clic encima de CERRAR Y CARGAR EN ... 


0J ii t I Comerciales - Editor de consultas 


□ X 


Agregar columna 


JtlJ 

Cerrary 

cargar 1 ' 

I ^ 50 Propiedades 

^ JU Editor avanzado 

Actualizar 
vista previa * 

| | gg zl i Tipo de datos: Texto - jj| 

L J " Usar la primera fila como encabezado ,r 

Administrar Reducir Dividir Agrupar . Comb 

columnas 1 ' filas 1 ” columna T por 42 Reem P ,azar los va,ores » 

Cerrary cargar ta 

Or... Transformar 


Cerrary cargar en. 


iHdk, 


1 Monica 

2 Monica 

3 Nicolas 

4 Nicolas 


Guarde los cambios en esta 
consulta, cierre la ventana Editor 
de consultas, y especifique donde 
quiere cargar los resultados. 

Afitiado- 


Configuracion de la co... x 


PROPIEDADES 

Nombre 


Conrercia es 


5 Marta On-Line 

6 Marta Afiliado 

7 Diego Off-Line 


Todas las propiedades 

^ PASOS APLICADOS 

Origen 

X Tipo cambiado 


En el cuadro de dialogo que emerge seleccionamos crear solo 
conexion y clic en el boton Cargar. 


Cargar en 

Selecrione como desea ver estos datos en el libro. 


h-h 

r 1 * Crear solo conexion 

I© 

Seleccione donde deben cargarse los datos, 

® Nueva hoja de callculo 

O Hoja de cakulio existente: 


JCS9 

□ s 


X 


Agregar estos datos al Modelo de datos 


(DC 




Cargar 


Cancelar 




Figura 5.15 - Crear Solo Conexion de la Tabla 



Cargar Tabla 


Crear Solo 
Conexion 


71 
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Combinar 

Consultas 


Repetimos el procedimiento para cargar la segunda tabla, 
posteriormente nos dirigimos al grupo OBETENER Y TRANSFORMAR 
y desplegamos las opciones de NUEVA CONSULTA, ubicamos 
COMBINAR CONSULTAS y pulsamos clic en COMBINAR. 


: ormulas Datos Revisar Vista Desarrollador Power Pivot Diseno Q ^Que de 


2 n Mostrar consultas IjP^ 

^ ^ Desde una tabla 

Nueva Actualizar 

consulta * L© Fuentes recientes todo . 

S Conexiones 

[HI Propiedades 

Editar vmculos 

w EE Y|^ Bo,,ar m 

■ rPj Volver a aplicar 

Z | Ordenar Filtro Textc 

y-Avanzadas co | ur 

| Desde un archivo ► 

| ^ Desde una base de datos ► 

Desde Azure ► 

Desde otras fuentes ► 

onexiones 

Ordenar yfiltrar 



G 

H 1 J H 


Combinar consultas ► 

Lr^ Combinar 

Biisqueda en catalogo de datos 
^ Mis consultas de catalogo de datos 
[q. Configuracion del origen de datos... 

[?) Opciones de consulta 

^ ^ ^ Anexar 

Combinar 

Combina dos consultas de este libro. 

Iniciar el Editor de consultas 

.filiarln 600.00 € 


Figura 5.16- Combinar Consultas 


En las listas desplegables de las opciones combinar escogemos las 
dos tablas, cuando aparezean las tablas seleccionamos la columna 
Medio en cada una de las tablas, para esto solo basta con pulsar clic 
en la etiqueta de columna de cada uno. Vease la figura siguiente 


jToma Nota! 



Algo importante que no habtamos mencionado, es que Power Query 
Ahora es Obtener y transformar, sus ventanas y consultas. En 
realidad, el amplio uso de Power Query por casi 7 ahos esta muy 
arraigado por lo que es poco probable que lo llamemos de otra 
manera, por lo menos en el desarrollo de este texto. 
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Combinar 

Seleccione tablas y columnas coincidentes para crear una tabla combinada. 


Comerciales 


Nombre 

Medio 

Monica 

On-Line 

Monica 

Off-Line 

Nicolas 

Off-Line 

Nicolas 

Afiliado 

Marta 

On-Line 


MontoDestinado 


Mes 

Medio 

Regalo 


Enero 

On-Line 

1000 


Enero 

Off-Line 

500 


Enero 

Afiliado 

600 


Febrero 

On-Line 

875 


Febrero 

Off-Line 

720 



Tipo de combinacion 

Externa izquierda (todas desde la primera, coincidiend... - 


>/ La seleccion coincide con 7 de las primeras 7 filas. 


Figura 5.17 - Combinor 


En la nueva columna pulsamos clic en el boton de "filtro" y 
escogemos las columnas que no estan visibles en la tabla, luego 
clic en Aceptar. 


1 File 

Inicio 

Transformar Agregar columna 

Vista 




At 

hi 

Q 

§0 Propiedades 

Editor avanzado 

ill 


SI 

il 

,V 

s 

Cerrary 

Actualizar 

Administrar 

Reducir 

Dividir 

Agrupar 

cargar- 

vista previa 


columnas- 

filas- 


columna' 

por 

Cerrar 


Consulta 



Or... 




Tipo de datos: Tabla 7 

Sq Usar la primera fila co 
^2 Reemplazar los valore 
Transformar 


SS. Nombre 0 Medio 0 NewColumn 0 

1 Monica On-Line Table r--—- 1 

2 Monica Off-Line Table - 

3 Nicolas Off-Line Table 

4 Nicolas Afiliado Table 

5 Marta On-Line Table 

6 Marta Afiliado Table 

7 Diego Off-Line Table 

0 Usar el nombre de columna original como prefijo 


Aceptar Cancelar 


• Expandir Agregar 
B (Seleccionar todas las columnas) 

E 

□ Medio 
E Regalo 


Figura 5.18 - Seleccionar las Columnas Faltantes 
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Vista Previa y 
Nueva Tabla en 
Power Query 


Ahora podemos ver una vista previa de la tabla, es importante 
darles a las nuevas columnas un nombre descriptivo e igualmente 
al nombre de la tabla. 


| Inicio 

Transformar Agregar columna 

Vista 




- © 


Propiedades 

Jf} Editor avanzado 

m 

m 

w 

21 

[ft 

rrri^ Tipo de datos: Texto ”■ 

™ Usar la primera fila como encabezado » 

& 

Cerrary Actualizar 


Administrar 

Reducir 


Dividir 

Agrupar . 

Comb *■ 

cargar ^ vista previa 


columnas ▼ 

filas ’ 


columna ” 

por ^2 Reemplazar los valores 


Cerrar 

Consulta 



Or... 


Transformar 



a* 

1 

Nombre Qj 

Monica 

Medio 

On-line 

Mes 

Enero 

Regalo 

1000 

Configuracion de la co.. 

X 

2 

Monica 

On-line 

Febrero 

875 



A 

PROPIEDADES 


3 

Monica 

On-line 

Marzo 

900 




Nombre 


4 

Marta 

On-Line 

Enero 

1000 




"ab a_Unificada 


5 

6 

Marta 

Marta 

On-Line 

On-Line 

Febrero 

Marzo 

875 

900 



Todas las propiedades 


7 

Monica 

Off-Line 

Enero 

500 



A 

PASOS APUCADOS 


8 

Monica 

Off-Line 

Febrero 

720 




Origen 


9 

Monica 

Off-Une 

Marzo 

920 




Se expandio NewColumn 

* 

10 

Nicolas 

Off-Line 

Enero 

500 




X Columnas con nombre cambi... 


11 

Nicolas 

Off-Line 

Febrero 

720 






■ 

NimliK 

Off-I iru» 

Mann 

Q?n 







Figura 5.19- Renombrar Columnas y Tabla 


En esta ocasion seleccionamos CERRAR Y CARGAR, ahora con la 
tabla podemos crear el reporte tabla dinamica solicitada. 

NOTA 


No es necesario cargar la 
tabla unificada a Excel, 
esto se hace asi para dejar 
el archivo y hacer el 
analisis, sin embargo, 
crear la tabla dinamica 
utilizando la opcion de 
conexion es un camino 
mucho mejor. 


Etiquetas de fila 

^ Suma de Regalo 

Diego 

2390 

Marta 

5375 

Monica 

5365 

Nicolas 

4790 

Total general 

17920 


Figura 5. 20 - Tabla Dinamica Solicitada 


Esto una forma alterna de trabajar el problema de una relacion 
muchos a muchos mediante Power Query, sin embargo, mas 
adelante en este texto se veran formas de hacerlo directamente con 
Power Pivot. 
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Tipos de Calculos Personalizados 

Tenemos dos exquisitos "sabores" para crear calculos que le den al 
mayor manjar en Excel, las tablas dinamicas por supuesto, esa 
sazon para consumir los reportes y analizarlos como jamas hubiera 
sido crefble y ejecutable. 



Pausemos un Momento 

Mi querido y amigo lector, de ahora en adelante emprendemos un 
viaje palpitante y lleno de emociones por la maravilla de descubrir 
tanta belleza y versatilidad en una funcionalidad, no obstante, hay 
que advertir que requiere de cierto cambio en como veniamos 
acostumbrados a trabajar, sin embargo, no significa para nada, que 
sea complejo, sino mas bien un nuevo camino. 


Esto dos sabores, estos dos tipos de calculos personalizados para 
nuestros reportes de tablas dinamicas son: 

■ Columnas Calculadas 

■ Medidas (Tambien conocidos como: Campos Calculados) 


Las Columnas calculadas son potentes, pero toda la autoridad y 
magia lo tienen las Medidas, por esto, iniciaremos brevemente con 
Columnas Calculadas quienes ademas tienen la ventaja de tener 
una similitud muy cercana con Tablas Estructuradas y las opciones 
antiguas de campos y elementos calculados, lo que nos permitira 
aprenderlas y dominarlas en un instante; posteriormente, 
entraremos en medidas, es mas, es el centro de practicamente 
todos los capitulos restantes del presente texto. 
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Columnas Calculadas 


NOTA 

Tambien puedes utilizar el 
comando AGREGAR que 
se encuentra en el grupo 
COLUMNAS de la pestana 
DISENO de la ventana de 
Power Pivot, este 
comando activa la barra 
de formulas DAX para 
empezar a escribir una 
expresion. 


Volvamos a nuestro archivo de pedidos de la seccion dos ya 
cargado en el modelo de datos, luego nos dirigimos directamente a 
la ventana de Power Pivot. Como pudimos conocer en el analisis 
exploratorio de la tabla pedidos, alii tenemos todos los costos 
asociados por una transaccion especifica, a pesar de ello, no 
contamos con una columna que nos indique el costo total ^Oue 
hacemos?; jAsi es! Una columna Calculada. 

Vamos al extremo derecho de la tabla pedidos y dejando la celda 
activa en la columna: "Agregar Columna" pulsamos clic en la barra 
de formulas DAX, lo primero que hacemos alii es digitar el signo 
igual (=), tal cual como en Excel para senalarle que lo que se escribe 


Observa como aqui 
aparece el nombre de 
la tabla pedidos, el 
mismo que tiene en la 
hoja, tambien note su 
icono, especial para 
indicar que es una 
tabla en el modelo de 
datos. 


La columna para una tabla 
tiene su propio icono, es igual 
que el de la tabla completo, 
pero con una columna oscura, 
nota que aparece el nombre 
de la tabla y entre parentesis 
cuadrados, el nombre de la 
columna. 


a continuacion es una formula, escribimos Tabla_Pedidos y vemos 
como sale un menu llamado IntelliSense con varias opciones. 


X V ^ = tab la pedidosl 


TABLA Pedidos 


RE _ 

j i a TH TABLA Pedi 
98069414 

TABLAPedi 

"1 

TABLAPedi 

m 
a 

TABLAPedi 
TABLAPedi 
TABLAPedi 
TABLA Pedi 



98069607 N 


dos[Gategona de Descuento] 
dos[Ciudad] 
do5[Costo de Erwio] 
do5[Costo del Producto] 
do5[Costo Empaque] 
dos[Fecha de Envio] 
dos[Fecha de Lfegada] 
dos[Nymero de Pedido] 
dos[Pais] 

dos[Precio de Venta] 


Figura 5. 21 - IntetliSense en lo borra de formulas DAX 
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En el IntelliSense podemos desplazarnos con las teclas de 
direccion y seleccionar con la tecla Tab o Enter. 

Notacion de Tablas en Power Pivot 

Antes de continuar es indispensable familiarizarse con la notacion 
de tablas en Power Pivot. 


Como se puede ver en la figura 5.21 al principio aparece el nombre 
de la tabla, lo que quiere decir que podemos utilizarla dentro de 
alguna formula DAX, mas abajo aparece el nombre de la tabla junto 
con el nombre de columna entre parentesis cuadrados de algun 
campo. Cosas a tener en cuenta: 


■ El nombre de una tabla puede tener espacios, pero para 
hacer referenda a ella debemos encerrar el nombre entre 
comillas simples ("), por ejemplo: 'SKU Productos', si el 
nombre no tiene espacios se puede omitir las comillas. 


■ Para hacer referencia a una columna se debe escribir un 
parentesis cuadrado de apertura despues del nombre de la 
tabla, con esto aparece el IntelliSense con la lista de campos 
de dicha tabla, no olvides cerrar los parentesis cuadrados. El 
nombre de columnas puede tener espacios. 


■ En Power Pivot no se puede hacer referencia a una celda 
especifica, solamente columnas completas o tablas. 

Procedamos ahora a escribir la siguiente formula: 


=TABLA_Pedido5[Co5to del Producto]+[Costo de Enviol+fCosto Empaque] 


NOTA 

Puedes hacer referencia a 
una columna 

seleccionando la columna, 
o cualquier celda de la 
columna deseada. 


Figura 5.22 - Ejemplo de Formula para Crear Columna Calculada 
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Renombrar 

Columna 

Calculada 


Ahora pulsa die derecho endma de la cabecera de la nueva 
columna, que por defedo queda con el nombre: Columna calculada 
1, clic en cambiar nombre de columna, renombrela como Costo 
Total. 


Las columnas 
calculadas se 
determinan por la fila 
actual. 



ivio | 

Fecha de Llegada 1 

Pais 

Ciudad | 

Costo Total * 

1 

00 :00... 

29/12/2015 00:00:00 

Uruguay 

MonteviH„_ 

12.72 

2 

0 :00:00 

25/12/2015 00:00:00 

Colombia 

Medellin 

8.5 

3 

0 :00:00 

18/12/2015 00:00:00 

Venezuela 

Caracas 

14.98 

4 

0 :00:00 

17/12/2015 00:00:00 

Argentina 

Rosario 

12.68 





Figura 5. 23 - Renombrar Columna Calculada 


jToma Nota! 



Renombrar la columna inmediatamente es Impresclndlble dado que 
en las versiones de Office 2013 y 2010 renombrar mas tarde implica 
cambiar donde se ha utlllzada dicho calculo, en Office 2016 el cambio 
ya se hace automaticamente. 


Utilizar Columna 
Calculada en 
Otra 


Podemos utilizar una columna calculada en la creacion de otras 
columnas calculadas sin ningun inconveniente, por ejemplo: crear 
la columna utilidad. 





m 








•mJf 


rmm& wmtf 

mjwmW 
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Si el lector tiene un buen conocimiento de tables estructuradas, se 
habra dado cuenta que la notacion y manipulacion de tablas y 
columnas en Power Pivot son muy parecidas a las de Excel. 


Como las 
Tablas 
Estructuradas 
de Excel 


Ciudad 


Costo Total 


- 0 . 


Vina del Mar 
lor Quito 
ribia Medellin 
uay Asuncion 
Lima 
Rio 

jay Montevideo 
Vina del Mar 
lor Quito 
my Montevideo 
my Montevideo 




=[@[Costo del Producto 
(€ 0. GO)]] +[@ [Costo de Envio 
(€ G.0G)]]+[ 


O Numero dePedido 
iiilTipo deCompra 
OSKU 

Ocategon'a de Descuento 
O Precio de Venta (€ 0.00) 

O Unidades (#:: 1-Digit) 

O Costo del Producto(€ 0.00) 

O Costo de Envio(€0.00) 

O Fecha de Envio(Dia/Mes/Ano) 
(OFecha de LlegadafOi'a/Mes/Ano) 
O Pais 


Figura 5. 25 - Notacion en Tablas Estructuradas 


DAX: Data Anlaysis expressions 

Hasta este punto hemos mencionado las formulas DAX, Pero ^que 
es esto en todo caso? Las siglas DAX son por Data Analysis 
expression quien es un lenguaje de formulas para Power Pivot, 
Power Bl y SSAS que le brinda al usuario la posibilidad de crear 
calculos personalizados; coloquialmente: Son las formulas para 
Power Pivot adaptado a su tipo de referenciacion columnas 
completas y tablas, que tienen el plus de extenderse a otras 
tecnologias de Microsoft. 


iNo es maraviliosa la promocion? "llevamos tres por el precio de 
uno" No solo aprendemos algo para Excel sino para otras 
tecnologias de Microsoft. 
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Renombrar 

Columna 

Calculada 


En el siguiente capitulo hablaremos un poco mas del lenguaje DAX, 
por lo pronto veamos un ejemplo sencillo de una funcion DAX. 


NOTA 

No te preocupes por el 
codigo del tipo de unidad, 
cuando se Mega al tercer 
parametro el IntelliSense 
aparece indicando los 
disponibles, para el caso 
del tercer argumento de la 
funcion DATEDIFF son: 

DAY (Dias) 

HOUR (Horas) 

MINUTE (Minutos) 

MONTH (Meses) 
QUARTERS (Trimestres) 
SECONDS (Segundos) 
WEEKS (Semanas) 

YEAR (Anos) 

La funcion DATEDIFF hizo 
su debut en Office 2016, si 

estas manejando una 
version anterior eta 
funcion no aparecera. 


En la tabla pedidos contamos con fecha de envio y llegada por lo 
que tenemos los datos suficientes para calcular el numero de dias 
que tardo la entrega, para esto nos podemos apoyar en una funcion 
DAX: DATEDIFF quien retorna el numero de unidades, es decir; dias, 
semanas, horas, etc. Que especifiquemos dado un intervalo de 
fechas, he aqui su sintaxis: 

DATEDIFF(<Fecha_lnicio>;<Fecha_Final>;<Unidad>) 


£ 


=DATEDIFF(TFecha de EnvioUFecha de Llegadal;DAY) 


Utilidad 

Dias de Entrega w 


206.31 

19 


210.53 

16 


204.05 

10 


206.35 

11 



Figura 5. 26 - Columna Calcula: Dias de Entrega con la Funcion DATEDIFF 


Tambien crea una columna calculada Semanas de entrega 



Pausemos un Momento 

Explora las funciones, con esto te familiarizards un poco con lo que 
contamos en el lenguaje, ademas, podras encontrar muchas 
funciones iguales a las de Excel, quienes tambien en su manejo son 
muy similares, si bien en el proximo capitulo se habla mas acerca del 
lenguaje DAX es bueno que lo vayas conociendo. 
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Medidas 

jHa llegado el momento de filosofar!, no nos mal interpretes no 
vamos abordar problemas sobre el significado del conocimiento y 
la realidad, no, sino que vamos atacar el problema fundamental de 
como y porque se calculan los datos en el area de valores. 


Cada vez que ponemos un campo en alguna de las areas de 
colocacion lo que hace la taba dinamica es extraer los elementos 
unicos de los campos y mostrarlos en una orientacion especifica o 
listarlos en algun lugar, claro exceptuando el area de valores. 


Tipo de Compra 



Etiquetas de columna 
Etiquetas de fila Q Blue-Ray 


Balck Fraday 
Cyber Monday 
Day Off Full 
Non 

Special Day 


El Area de valores es diferente, es la unica de las areas de colocacion que tiene un 
comportamiento completamente disimil. 


Cuando agregamos un 
campo al area de filtros 
lista todos los elementos 
(items) unicos del 
campo en una lista 
desplegable para asi 
poder filtrar. 


Cuando agregamos un 
campo al area de 
columnas lista todos los 
elementos (items) unicos 
de forma horizontal 
cada uno en su propia 
celda. 


Cuando agregamos un 
campo al area de filas 
lista todos los elementos 
(items) unicos de forma 
vertical cada uno en su 
propia celda. 
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Area de 
Colocadon - 
Valores 


Esta bien definido que las areas de colocadon deben mostrar de 
alguna manera dependiendo de su naturaleza los elementos unicos 
del campo en el area determinada, si hay mas de un campo muestra 
dichas listas unicas "anidadas", todo esto es claro, preciso y no deja 
duda de su comportamiento, pues es lo unico que puede suceder, 
peroooo... 


HOUE 5UCEDE CON EL AREA DE VALORES? 


Cuando agregamos un campo al area de 
valores que comportamiento debemos 
esperar, <;es claro y bien definido? 


Arrastrar campos entre las areas siguientes: 


T FILTROS 

III COLUMNAS 

T pc :1c Comp j ^ 

Cateqcra ▼ 



“ FI LAS 

X VALORES 

Categona de Descue.. w 

Costc^Jotall 



Aplazar actualizaci6n del disefto 


Figura 5. 27 - Agregondo Campos al Area de Valores 


Tal vez estes pensando, ^que close de pregunta es esa? Todos 
sabemos que realiza la suma si es un campo numerico o una cuenta 
si es un campo de tipo texto. 


Si y entiendo el punto, pero la cuestion aqui es ^Por que? iPor que 
la suma? iPor que la cuenta (si el campo es texto)? Es decir, en las 
demas areas sabemos con certeza que pasa alii, dado que siempre 
va a listar los elementos unicos, no hay mas opcion; pero en el area 
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De valores pueden pasar muchas cosas, dado que es el tipo de 
calculo que queremos que se presente en el cuerpo de la tabla 
dinamica, de alguna manera la forma correcta seria antes de anadir 
el campo o junto con el, decirle al area de valores que calculo 
queremos que se realice: SUMA, CUENTA, PROMEDIO, etc. Sin 
embargo, lo que sucede es que tiene un compartimiento por 
defecto, implfcito, con el cual estamos muy habituados, pero en 
realidad deberiamos ser explicitos, definir nosotros mismos antes 
de ir al area de valores, que tipo de calculo queremos ver alii. 

El lector tambien podra estar pensando: "Si, impiicitamente lo 
funcionalidad de tablas dinamicas indican si es una sumo o cuenta 
dependiendo del campo, no obstante, yo puedo definir mas tarde si 
quiero cambiar el tipo de calculo, ya que puedo seleccionar algunas 
de las funciones de resumen, por ejemplo, PROMEDIO" Y por 
supuesto estas en lo correcto, a pesar de ello, sigue siendo tanto 
implicito como limitado, lo decimos porque despues de anadir el 
campo es que se define el tipo de calculo dado un conjunto de 
funciones de resumen supremamente restringido. 

Las Medidas son eso: el tipo de calculo "Funcion de Resumen" que 
queremos ver en el cuerpo de la tabla dinamica y cuya definicion 
la hacemos antes de agregar el "campo" al area de valores, es decir, 
se definen de manera explicita. 

iComo? - Tal vez te cuestiones. 

Sencillo mi amigo, con el modelo de datos y el lenguaje DAX. 


Medidas 

Implfcitas 


Medidas 

Explicitas 





jSUFICIENTE FI LOS FI A, A LA ACCION! 
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Tabla Dinamica, 
Tipo de Calculo 
Clasico 


Creemos una tabla dinamica con el modelo de datos igual que la 
presentada en la figura 5.26, pero agregando el campo Costo Total 
al area de valores y con funcion de resumen PROMEDIO. 


Supon ahora que deseas hacer la misma tabla dinamica, pero en 
lugar de utilizar PROMEDIO te gustaria utilizar la MEDIANA, aunque 
somos conscientes que en las funciones de resumen no hay 
ninguna con estas caracteristicas iOue hacer? 


NOTA 

Si el lector no recuerda 
muy bien los elementos 
de la interfaz de Power 
Pivot, por favor toma una 
pausa y repasa el capitulo 
3, es mejor tener todo 
100% claro. 


El lector mas atento ya habra intuido que con una medida explicita 
y utilizando en lenguaje DAX ^Cdmo? Aun no lo hemos visto, pero 
vamos a ello. 

Vamos a la ventana de Power Pivot y nos ubicamos en la hoja con 
nombre TABLA_PecHdos, en la parte inferior (En el Area de Medidas) 
dejamos la "celda" activa y pulsamos clic en la barra de formulas 
DAX, escribimos entre parentesis el nombre de la medida, para este 
caso llamamos a la medida: [Mediana Cost. Tot], y posteriormente 
digitamos dos puntos (:) y el signo igual (=), de esta manera Power 
Pivot sabe que se va escribir, a continuacion, una expresion que 
corresponde a una medida y no a una columna calculada, ahora 
procedemos a escribir la funcion MEDIAN, en su unico argumento 
vamos poner la columna Costo total de la tabla Pedidos. 


Aqui tambien contamos 
con el IntelliSense 


A IfMediana Cost. Totl:=MEDIANfTABLA Pedido 5 rC~ 



MEDIA N (Col unn';. 

TABLA_Pedidos[Costo de Envio] 

En Pedidos[Co5to del Producto] 

TABLA_Pedidos[Co5to Empaque] 


TABLAPp dido s[Co 5to Total] 


}... 

00 

00 


Figura 5. 28 - Agregando Medida con la funcion MEDIAN 
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Percatate como ahora en el area de medidas aparece la recien 
creada, junto con el resultado aplicado a toda la tabla (Si se hacen 
filtros en La tabla el resultado cambia mostrando el valor de la medida 
de acuerdo a la tabla visible en Power Pivot). Sino observas el 
nombre complete ni el calculo vuelve la columna mas ancha hasta 
que pueda observar todo. 


24 

25 

03 1 


03 

1 








Mediana Cost. Tot: M.72 









| 





Figura 5.29- Medida Creada 


Para dejar claro la funcion MEDIAN, demos una definicion: La 
funcion MEDIAN en DAX retorna la mediana de los numeros de una 
columna, esta funcion cuenta con un unico argumento y es 
precisamente la columna deseada, su sintaxis: MEDIAN 
(<Columna>). El tipo de valor que retorna es un numero decimal. 


NOTA 


La funcion MEDIAN en 
Power Pivot se estreno en 
la version de Office 2016, 

por lo que, si el lector esta 
trabajando con Office 
2010 o 2013 debe buscar 
una alternativa, para ello 
vease el Anexo B que 
provee un patron o 
Snippets DAX alterno para 
crearla. 


Funcion 

MEDIAN 


Procedamos en este instante a crear una tabla dinamica con el Tabla 

modelo de dates justo debajo de la tabla dinamica creada Dinamica 

con DAX 

antenormente, quien ademas tenga la misma configuracion en las 
areas de colocacion, exceptuando el campo en el area de valores; 
alii vamos agregar la medida recien creada, [Mediana Cost Tot], esta 
la podemos encontrar en donde estan los campos de la tabla 
Pedidos dado que fue en dicha tabla en Power Pivot donde se creo, 
observa que las medidas tienen el simbolo Fx en su extremo 
izquierdo para asi identificar que fue una medida creada de 
manera explicita en el Modelo de Datos / Power Pivot 

fiPMiPf lii 
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Una vez identificada La medida llevamos esta aL area de valores de 
La tabLa dinamica. 



Pausemos un Momento 

Ftjate como el tipo de calculo ("La funcion de Resumen") ha sido 
prevlamente definida antes de ser agregada al area de valores, esto 
es expllcito y brinda con ello beneficios extraordlnarios, por esto si lo 
que necesitas es una SUMA acostumbrate a hacerlo todo de manera 
expllcita. 


Presta especiaL atencion mi amigo como Los resuLtados de ambos 
reportes son simiLares mas no identicos, pues sabemos que tanto eL 
promedio como La mediana son medidas estadisticas de 
centralizacion, pero con diferentes enfoques y escenarios de 
aplicacion donde una puede ser de mayor utiLidad que otra. La 
mediana es exceLente cuando tenemos valores atipicos y queremos 
omitirlos, por ejemplo, descuentos que incrementan las ventas, y 
deseamos hacer un analisis con Los valores mas comunes. 
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Tipo de Compra All 


□ 


Promedio de Costo Etiquetas de columna Q 





Etiquetas de fila 

Q Blue-Ray 

CD 

Combo 

Libro 

Total general 

Balck Fraday 

14.54 

14.61 

14.55 

14.67 

14.61 

Cyber Monday 

14.75 

14.50 

14.61 

14.60 

14.61 

Day Off Full 

14.80 

14.35 

14.71 

14.66 

14.67 

Non 

14.65 

14.61 

14.65 

14.68 

14.66 

Special Day 

14.53 

15.16 

14.88 

14.65 

14.77 

Total general 

14.67152424 

1 4.588 

14.646 

1 4.656 

H 4.6491 13 

Tipo de Compra 

All 0 





Median a Cost. Tot Etiquetas de columna Q 





Etiquetas de fila 

Q Blue-Ray 

CD 

Combo 

Libro 

Total general 

Balck Fraday 

14.76 

14.68 

14.50 

14.72 

14.72 

Cyber Monday 

14.80 

14.40 

14.68 

14.68 

14.68 

Day Off Full 

14.68 

14.21 

14.76 

14.72 

14.72 

Non 

14.72 

14.68 

14.72 

14.72 

14.72 

Special Day 

14.47 

15.33 

15.00 

14.72 

14.90 

Total general 

1 4.72 

1 4.66 

1 4.72 

14.72 

1 4.72 


Reporte de tablas 
dinamicas creado con una 
medida implicita, la 
funcion de resumen 
PROMEDIO (A lo clasico). 


Reporte de tabla dinamica 
creado con una medida 
explicita utilizando 
funciones DAX para 
mayor versatilidad 
mediante el modelo de 
datos). 


Figura 5. 31 - Tablas Dinamicas 


Reflexionemos acerca de lo que acaba de suceder: 


■ Con las Medidas podemos indicar de manera explicita lo que 
queremos hacer en el area de valores. 


■ Las Medidas utilizan DAX, y como el lector pudo haber 
notado de su exploracion contamos con un buen numero de 
funciones (que por cierto no para alii) 


■ Contamos en el lenguaje DAX con las antiguas funciones y 
nuevas, yendo mas alia de lo que incluso pudimos imaginar 


■ La Medidas y el lenguaje DAX sirven perfectamente para 
multiples tablas relacionadas. 


IEstas viendo to mismo queyo? jTODO EL PODER Y POSIBILIDADES PARA 



CREAR CALCULOS PERSONALIZADOS, UNCIAMENTE LIMITADOS POR 
NUESTRA IMAGINACION! - YESTO ESSOLO EL PRINCIPIO. 
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Definicion del Modelo de Datos y Otros 

Antes de finalizar este capitulo definamos que es el modelo de 
datos y otros conceptos relacionados. 

Definicion: El Modelo de Datos 

El Modelo de Datos consiste en el conjunto de tablas, relaciones 
mediante declaraciones, Medidas, Columnas Calculadas, Jerarquias, 
KPIs y otros objetos para expandir las facultades y realizar analisis 
de datos orientado a Business Intelligence. 

Definicion: El Modelo de Datos Interno 

El Modelo de Datos Interno son las posibilidades que tenemos en 
aquellas versiones de Office que no tienen el complemento de 
Power Pivot full, con ello podemos utilizar una pequena parte del 
modelo de datos como crear relaciones (NO mediante vista de 
diagrama) y utilizar eltipo de funcion de resumen: Contar Distintos; 
Asi podemos crear modelos de datos con el uso de Power Pivot 
indirectamente. 


Definicion: Columna Calculada 


Tipo de Calculo personalizado que extiende las columnas de una 
tabla mediante operaciones entre otras columnas, elementos y con 
el lenguaje DAX. Las columnas calculadas no suponen una 
revolucion como las medidas, pero tienen aplicaciones avanzadas 
baste interesantes y de utilidad, ademas si que brindan muchas mas 
capacidades que la antigua opcion clasica de columnas calculadas. 
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Definicion: Medidas 

Tipo de Calculo personalizado que nos permite crear todo tipo de 
resumen para el cuerpo de una tabla dinamica mediante el uso del 
lenguaje DAX, a esta las llamamos Medidas Explicitas, para 
diferenciarlas de las funciones por efecto Medidas Impiicitas. 

El Siguiente Paso 

En el proximo capitulo vamos a realizar un emocionante recorrido 
por las funciones y conceptos basicos del lenguaje DAX. para asi ir 
familiarizando con las mas comunes, que para nosotros, los 
usuarios de Excel, es bastante facil e intuitivo pues los 
fundamentos en DAX empalman a la perfeccion con las funciones 
clasica en Excel, de alii veremos que muchisimas de ellas son 
similares, lo anterior es una parte importante para ir ganando 
terreno y posteriormente adentrarnos conceptos mas complejo y 
utilidades avanzadas, y asi convertirnos en unos verdaderos 
gladiadores en la construccion de modelos de datos y el lenguaje 
DAX. iQue Esperamos? jA la Carga! 




La Presente Pagina se ha dejado en Blanco de forma deliberada. 




Capitulo 6 


Bienvenidos al Pais de las Maravillas: 

Lenguaje DAX 
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Descifrando los Crujientes Nuevos 
Calculos 


Ya conocimos e introdujimos los dos nuevos tipos "crujientes" de 
calculos personalizados: Columnas Calculadas y Medidas, no 
obstante, antes de continuar con el lenguaje DAX repasaremos 
estos dos tipos de calculos para ver unos puntos criticos. 


Columnas Calculadas: Analisis 


Percatate como la formula 
es igual para toda la 
columna, dicho de otro 
modo, si seleccionamos 
"celda por celda" veras que 
las formulas son 
exactamente identicas. 


Para estar 100% seguros de que las comprendemos en un primer 
nivel vamos a estudiar el Campo Calculado: Costo Total. 


A pesar de que es la misma 
formula, para cada celda de 
la columna, los valores son 
diferentes, esto es asi porque 
la operacion indicada se 
ejecuta en la fila actual. 



=TABI A Pedido5fCo5to del Producto]+fCo5to de Envia]+[Costo Empaque] 


Costo de Envio 


I Costo Total 




-a—*' 


5.25 

3.25 

3 


t 1 

11.5 

8.99 

5.99 

3 


J 

17.98 

7.84 

4.34 

3 


\\\ 


15.68 

8 

6 

3 




17 


Figura 6. 1-Analizando Columna Calculada Costo Total 


15.72 


* — © 

asi, 


Este valor de la "celda" se calcula con la fila actual, asi: 17.98 = 8.99+5.99+3, esto es asi, 
porque de esta manera lo senala el DAX Engine. Puedes imaginar dicha formula como una 
funcion matricial, o si lo prefieres puedes visualizarlo como un bucle que va iterando, filtrando 
fila por fila y aplicado la formula senalada, donde dicho bucle arranca en 1 y termina en la 
ultima fila de la tabla. 


jToma Nota! 



No se puede hacer referenda a una celda individual en Power Pivot, 
recuerda que en el modeio de datos la referenda trabaja con 
columnas ytablas, nunca con celdas individuales, sise desea que una 
serie de filas tenga un compartimiento diferente se debe utilizar 
funciones como IF o SWITCH. 
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Las Columnas Calculadas se ejecutan y crean antes de tener una 
tabla dinamica, por lo que estas columnas se almacenan en 
memoria y ocupan espacio, dado que su creacion es antes decimos 
que las columnas calculadas se determinan en tiempo de carga. 


Medidas: Anadir Implicitas como Explicitas Rapido 

Como mencionamos en el capitulo anterior es importante 
acostumbrarse a crear todas las medidas explicitas, incluso 
aquellas que estan por defecto en tablas dinamicas; de hecho, 
Microsoft sabe esto y por eso puso a nuestra disposicion las 
opciones de autosuma, para crearlas rapidamente. PESTANA 
diseno, Grupo CALCULOS, Comando AUTOSUMA opcion SUMA. 


m 

Jos Ordenar por 
is columna* 

ar y filtrar 


Buscar 

Buscar 


Precio de Venta 


222.03 

222.03 

222.03 

222.03 


£ Autosuma ▼ 

S Suma 
Promedio 
Recuento 
Recuento distinto 
Max. 

Min, 


✓ista de Mostrar Area de 
liagrama oculto calculo 

Ver 




222.03 

222.03 


Mediana Cost. Tot: 14.72 


Figura 6.2- Opcion Autosumo pora Medidas 


Con Autosuma no tenemos excusas para crear medidas implicitas, 
puedes agregar todas agilmente. Debes tener en cuenta que si se 
desea la suma de costo total debes dejar la celda activa en el area 
de medidas debajo de la columna costo total. 




Tiempo de 
Carga 


Autosuma para 
Medidas 


NOTA 

Puedes notar la ausencia 
en las opciones de 
Autosuma de Producto, 
Desviacion estandar 
muestral y poblacional, es 
asi porque a lo largo de 
los anos no han sido 
ampliamente utilizadas, en 
lugar a ellas tenemos 
Recuento Distinto, la cual 
es muy util para el analisis, 
en todo caso si necesitas 
Producto o desviacion 
estandar, el lenguaje DAX 
lo permite "todo". 
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Como las medidas se agregaron en la tabla Pedidos podemos 
encontrarlas en el panel de campos desplegando las columnas de 
la misma tabla, de allf podemos llevar la suma al area de valores, 
tipo de compra y descuento al area de filas y descuento (%) al area 
de columnas. 



Figura 6.3- Medidas Agregadas con Autosuma 


La medidas se calculan de acuerdo a las coordenadas de una celda 
especifica en el cuerpo de la tabla dinamica, por ejemplo, tome el 
valor 347057.19 de la imagen anterior, dicho numero se calcula 
porque esta restringido por: Non, 0 y Devolucion ; es decir por el 
conjunto de elementos que rodea la celda (el conjunto defiltros que 
se aplicaria si todo estuviere en una tabla unificada donde 
posteriormente se aplica la formula senalada) a este conjunto de 
Contexto de celdas las llamamos contexto de filtros; puedes leer la medida 

Filtros Suma ofPrecio de Venta como: La Suma de los valores de la columna 

Precio de Venta en el contexto Actual, asi es mas preciso. 


Tiempo de Las me didas se calculan en tiempo de consulta, es decir, cuando se 

Consulta agrega al area de valores, por lo que no ocupa espacio en memoria, 

solamente se ejecuta en esta circunstancia, antes solo es definicion. 
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Otra Forma de Agregar Medidas 

Hasta el momento hemos agregados medidas desde la ventana de 
Power pivot en el area de medidas, sin embargo, tambien lo 
podemos hacer desde Excel, simplemente vamos a la pestana 
POWER PIVOT, GRUPO CALCULOS, desplegamos las opciones de 
MEDIDAS y pulsamos clic en NUEVA MEDIDA. 



Inicio 


Administrar Medidas KPI 


Insertar Diseno de pagina Formulas Datos 




Agregar a Actualizar Detectar Con 
modelo de datos todo 


Modelo de datos Nueva medida... 

£IQ ^ Adi Nueva medida 


las 


Relaciones 


Crear una nueva medida 


Figura 6.4- Agregar Medida Desde Excel 


NOTA 

Tambien puede desplegar 
el cuadro de dialogo 
medidas pulsando clic 
derecho encima del 
nombre de una tabla en el 
panel de campos de tablas 
dinamicas. 


Con eso, aparece un cuadro de dialogo llamado MEDIDAS, 
anadimos aqui por ejemplo la desviacion estandar. 



En esta lista desplegable 
seleccionamos la tabla en la cual 
queremos anadir la medida, en este 
caso Pedidos. Buena Practical Las 
medidas se deben asignar a la tabla 
que contienen las columnas 
numericas usadas en la formula. 


Nombre: Desviacion Precio 
de Venta, por ejemplo. 


Al igual que en Power Pivot a 
medida que vamos escribiendo el 
IntelliSense aparece para 
ayudarnos, en este caso 
necesitamos la funcion STEDV.P 
que es la desviacion poblacional. 


Figura 6.5- Cuadro de Dialogo Medidas 


Aplicar formato en las opciones 
de categoria. / Buena Practical 
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NOTA 

iDonde es dptimo escribir 
las Medidas? 

Los usuarios de Excel 
deberian escribir las 
formulas DAX desde Excel 
utilizando el cuadro de 
dialogo, debido a que 
brinda una experiencia 
amena y despues de 
crearla se agrega 
inmediatamente a la tabla 
dinamica con lo cual 
podemos visualizar 

instantaneamente si lo 
que hemos elaborado es 
lo deseado. 

Opciones de Formato 

Acostumbrate a 

establecer el formato de la 
medida (porcentaje, 
moneda, etc.) en las 
opciones de formato del 
cuadro de dialogo (Mease 
la figura anterior ayuda 
visual 4) ya que cuando se 
aplica alii se empleara a 
cualquier tabla dinamica 
que creemos y que use 
dicha medida. Si te has 
acostumbrado a crear las 
medidas en Power Pivot 
asigna el formato en la 
pestana FORMATO de la 
ventana t, esto tendra el 
mismo efecto. 


Columnas Calculadas Vs Medidas 

Llegados a este punto somos mas que consientes que los dos tipos 
de calculos son bien diferentes, el valor de una columna calculada 
se ejecuta en tiempo de carga y se determina fila a fila, por otra 
parte, una medida se calcula en tiempo de consulta y depende de 
como configuremos los campos en la tabla dinamica. 

Cuando Utilizar el Uno o el Otro 

Como los dos tipos de calculo son el centro de gravedad de Power 
Pivot vamos a recalcar aun mas, la diferencia entre una columna 
calculada y une medida en el modelo de datos, con el apoyo de las 
dos tablas que dejamos abajo. 



Cuando Utilizar Columna Calculada o Medida 


Columna Calculada 

Cuando se necesitan elementos extras para Slicer o Area de Colocacion. 
Crear una Expresion que este ligada a la fila actual. 

Categorizar numeros o textos. 


Medidas 

Cuando se quiera mostrar un calculo en el area de valores 
Cuando queramos elaborar un modelo de datos eficiente 

jEl Ganador! 

En algunas ocasiones se pueden utilizar las dos opciones, cuando 
esto suceda utiliza medidas, ahorran espacio en memoria. 
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Algunos Fundamentos 

Antes de dar un tour por Las funciones DAX mas comunes vamos a 
ver una serie de conceptos basicos pero imprescindibLes. 

Tipos de Operaciones 

Como se pudo apreciar en la creacion de las columnas calculadas 
pudimos utilizar la suma con el operador (+), el modelo de datos 
cuenta con sus operadores bien definidos y para no dejar lugar a 
situaciones ambiguas las tablas siguientes los detallan. 


^ Operadores Aritmeticos en el Modelo de Datos 


Sfmbolo 

Description 

+ 

Adicion Matematica 

- 

Sustraccion Matematica 

* 

Multiplicacion Matematica 

/ 

Division Matematica 

A 

Potenciacion Matematica 



Operadores de Comparacion en el Modelo de Datos 


Sfmbolo Description 

- 

Igualdad 

<> 

Diferente de 

> 

Mayor Que 

> = 

Mayor o Igual Que 

< 

Menor Que 

< = 

Menor o Igual Que 
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NOTA 

Los operadores logicos 
tambien tienen sus 
equivalentes en el 
lenguaje DAX, con sintaxis 
muy parecidas a las de 
Excel (AND, OR, NOT). 

Las Disyuncion logica 
Exclusiva (XOR) no esta 
disponible. 



Operadores Logicos 


Simbolo Description 

&& Conjuncion Logica (Y) 

Disyuncion Logica Inclusiva (0) 
! Negation Logica 



Operadores de Texto 


Simbolo Description 

& Concatenation 


NOTA 

Podemos alterar el orden 
en el que se ejecutan los 
calculos por defecto 
mediante la utilizacion de 
parentesis (), al igual que 
en Excel. 


Orden de Calculos 

Estas operaciones son similares a las de Excel, lo nuevo son los 
operadores logicos, no obstante, adaptarse a ellos es bastante 
rapido. Asi como en la hoja de calculo (Excel), las operaciones en 
Power Pivot siguen un orden de ejecucion, asi: 

■ Ejecutar Multiplicaciones y Divisiones (*,/) 

■ Ejecutar Sumas y Restas (+,-) 

■ Ejecutar Concatenaciones (&) 

■ Ejecutar Operaciones Logicas (<,>,<=,>=,&&,||,!) 


jToma Nota! 



Todas las operaciones a exception de las de texto se agrupan en 
categortas de precedencia, estas que tienen el mismo nivel se 
ejecutan de izquierda a derecha. 
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Tipos de Datos 

El termino tipos de datos en el modelo de datos se utiliza para 
englobar el atributo de una columna sobre la clase de datos que 
hospeda, para ponerlo simple: el tipo de dato indica si es un 
numero, texto, moneda, etc. El lenguaje DAX soporta siete tipos de 
datos con los cuales puede realizar operaciones sin ninguna 
dificultad, la siguiente tabla los nombra y describe fugazmente. 


^ Tipos de Datos en Power Pivot 


Sfmbolo 

Descripcion 

Integer 

Numero entero que puede almacenar 64 Bits 

Float 

Numero decimal con doble precision 

Currency 

Numero decimal con coma decimal variable para moneda 

Date 

Numero decimal donde la parte entera indica el dla y la fraction 
bora 

True/False 

Valor Booleano falso o verdadero 

Text 

Un texto, como un String en VBA 

BLOB 

Utilizado en imagenes (Power Pivot no lo Soporta jNO LE 

AGRADA MUCHO! =) ) 


NOTA 

El Tipo de dato BLOB es 
utilizado por Power View 
para mostrar imagenes 
que se almacenan 
directamente en el 
modelo de datos, aparece 
aqui para cuando se utilice 
el modelo de datos en 
Power Pivot todo sea 
compatible y la imagen se 
muestre correctamente. 


jToma Nota! 



El DAX Engine tiene un poderoso y refinado sistema para manejo y 
detection de tipos de datos, por lo que en la gran mayorta de 
situaciones u ocasiones no debemos preocuparnos por esto. La 
deteccion del tipo de datos se basa en la operation que se haga entre 
columnas y no los tipos de datos involucrados. 
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Al igual que en Excel el 
modelo de datos 
agrupa sus funciones 
DAX por categonas 
para relacionarlas por 
grupos afines. 



La Habitacion de las Funciones 
(Comunes) DAX 

Es tiempo de dar un breve vistazo a La "habitacion" que contiene 
Las funciones DAX mas comunes y asi irnos habituado a eLLas, en 
esta seccion Las veremos agrupadas en categories, mencionando 
aLgunas brevemente, dado que eL uso de Las funciones DAX 
avanzadas y apLicaciones robustas requiere de cierta teoria 
fundamental que sera tratada en eL proximo capitulo, no obstante, 
en la presente seccion veremos un grupo "selecto" de funciones 
DAX para hacer cosas bien interesantes. 

IHas visto el icono Fx en la barra de formulas DAX en la ventana de 
Power Pivot?, apuesto a que si, hasta me atrevo a decir que has 
explorado este cuadro de dialogo, pues bien, vamos a el y 
despleguemos, alii veremos las categonas. 


Insertarfuncion 
Seleccione una categoria: 


X 


Todos 

V 

Todos 


Fecha y hora 


Matematicas y trigonometna 


Texto 


Logico 


Filtro 


Informacion 


Primario/secundario 



Returns the absolute value of a number. 


Aceptar 


Cancelar 


Figura 6.6- Cuodro de Dialogo Insertar Funciones 
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Como se puede observer en la figura anterior, tenemos ocho 
categories de funciones, pues bien, este cuadro de dialogo nos esta 
enganado, la verdad es que tenemos diez categonas: 


■ FechayHora 

■ Matematicas y Trigonometricas 

■ Estadisticas 

■ Texto 

■ Logicas 

■ Filtro 

■ Informacion 

■ Primario / Secundario 

■ Time Intelligence 

■ Miscelaneas 


NOTA 

Estas son las categonas 
que ha definido Power 
Pivot, para agrupar las 
funciones DAX 

coherentemente, empero, 
podemos definir otros 
grupos "virtuales" de alii 
para estudiarlos de una 
manera mas "apropiada" 
o por conveniencia. 


La primera es Time Intelligence, este grupo de funciones es 
increiblemente sorprendente, solo con esta categoria podemos 
determinar unos calculos para nuestros analisis de otra dimension; 
time Intelligence no aparece alii listado porque estos se habilitan 
con ciertas caracterfsticas, esto es tablas de calendario cuya 
importancia requiere de su propio capitulo que se vera mas 
adelante. Por otra parte, la categoria Miscelaneas encierra unas 
funciones que no pueden ser asignadas a ninguna categoria. 

Nosotros personalmente tambien a algunas de estas categonas las 
subdividamos en grupos aun mas pequenos, por ejemplo: 


■ Estadisticas 


S Funciones de Conteo 



S Funciones Descriptivas 
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Asf mismo, es bien conocida una categoria "virtual" de funciones 
Uamadas de agregacion, categoria la cual contiene funciones de 
otras categories, a continuacion, se listan las mas usuales. 

■ Funciones de Agregacion: 

1. SUM 

2. PRODUCT 

3. AVERAGE 

4. STDEV.S 

5. STDEV.P 

6. MAX 

7. MIN 

8. VAR.P 

9. VAR.S 

10. MEDIAN 

11 PERCENTILE. EXC 

12 PERCENTILE.INC 

13 DISTINCCOUNT 
14. COUNT 

En esta seccion vamos a estudiar: 

■ Funciones de Agregacion 

■ Funciones de Conteo 

■ Funciones Logicas 

■ Funciones de Fecha y Hora 

■ Funciones de Informacion 

■ Funciones de Texto 
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Funciones de Agregacion 

Para entender esta categoria de funciones vamos a crear la 
siguiente columna calculada de forma provisional, 
=SUM(TABLA_Pedidos[Costo Total]). Observemos el resultado. 


] Columna Provison... w 

364631.060000005 


364631.060000005 
364631.060000005 
364631.060000005 
364631.060000005 
364631.060000005 
364631.060000005 
364631.060000005 
n^nnnnnns 

Figura 6.7 - Columna Calculada Provisional 



Todos los valores de las 
distintas celdas de la 
columna hallados con la 
funcion de agregacion 
SUMA son iguales, ^Sabes 
por que? 


El resultado a lo largo de cada celda de la columna es igual Por 
que? - No habiamos visto que las columnas calculadas operan como 
si se fuera filtrando fila porfila y aplicando la formula senalada, es 
decir, lo que realmente deberiamos esperar es que cada celda 
tuviera exactamente el mismo valor que su celda correspondiente 
en la columna costo total, esa seria la logica iCierto ?, a pesar de 
ello, si nos detenemos un momento y pensamos en la funcion MAX, 
PRODUCT, MEDIAN, etc. Ellas darian el mismo resultado, por lo que 
seguir esta logica tiene algo bien extrario, con las funciones de 
agregacion estariamos replicando otra columna, lo cual aparte de 
ser un desperdicio, tambien seria algo absurdo ^No crees? Ya 
sabemos a lo que voy y cual es la conclusion de ello, incluso ya 
sabras a que corresponde los valores que aparecen en la figura, 
para dejarlo transparente pongamoslo en la siguiente nota. 
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NOTA 

Todas las funciones de 
conteo descritas en la 
tabla son de agregacion, 
sin embargo, no todas las 
funciones de agregacion 
se listaron alii, las que no 
se mencionan aqui 
necesitan de cierta teorfa 
para comprenderlas 
perfectamente por lo que 
se abarcan en capitulos 
posterior. 



jToma Nota! 

Las funciones de agregacion siempre se aplican a la columna entera 
yse expanden si se agregan mas registros, de esta manera cada una 
tendra un resultado distinto (Entre Funciones de Agregacion). En la 
figura anterior todos los resultados son iguales porque se aplica a la 
columna completa y permanece constante en todas las celdas. 


Funciones de Conteo (De las Funciones Estadisticas) 

Las funciones de conteo son aquellas que nos sirven para, valga la 
redundancia, contar todos los elementos de una columna o tabla 
que cumplan con ciertas caracteristicas, hay cinco claves que 
listamos inmediatamente. 



Funciones Claves de Conteo 

Funcion 

Description 

COUNT 

Cuenta el numero de celdas en una columna que 
tienen numeros. 

COUNTA 

Cuenta el numero de celdas que tienen numeros, 
valores logicos y texto en columna. 

COUNTBLANK 

Cuenta el numero de celdas vadas en una columna. 

COUNTROWS 

Cuenta el numero de filas que tiene una tabla. 

DISTINCTCOUNT 

Cuenta el numero de celdas diferentes en una 
columna. 


Para simplificar, de ahora en adelante cada vez que creemos una 
medida aparecera asi: 

Nombre_Tabla[Nombre Medida]:=FUNCION(Tabla[Columna]) 
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EjempLifiquemos para mayor claridad. 


TABLA_Pedidos[Mediana Cost.Tot]:= 

MEDIAN(TABLA_Pedidos[Costo Total]) 

Esta fue la medida que creamos en el capitulo cinco con nombre. 
Mediana Cost Tot, que calcula la mediana de la columna Costo Total 
de la tabla pedidos, habran funciones con mas de un argumento, 
eso se separa por punto y coma (;). Por otra parte, las columnas 
calculadas se indicaran asi: 


[Utilidad]=[Precio de Venta]-[Costo Total] 


NOTA 

La diferencia para indicar 
los dos tipos de calculos 
radica en su operador de 
asignacion, para medidas 
se utiliza dos puntos e 
igual (:=) despues del 
nombre y antes de escribir 
la formula, mientras que 
para columnas calculadas 
se utiliza el signo igual 
solito (=). 


Vislumbremos el basto universo del lenguaje DAX con las recien 
introducidas funciones de conteo, para ello proseguimos a crear 
las siguientes medidas en su orden: 


TABLA_Pedidos[# de dias que hubo ventas]:= 
DISTINCTCOUNT(TABLA_Pedidos[Fecha de Envio])] 

TABLA_Pedidos[Transacciones]:= 

COU NTROWS(TABLA_Pedidos) 

TABLA_Pedidos[Consistencia]:= 

[# de dias que hubo ventas]/[ Transacciones] 


Ahora si, creamos un reporte donde el campo fecha de envio vaya 
en el area de filas y la ultima medida en el area de valores, 
tenemos: 
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NOTA 

En la tabla Pedidos 
asumimos que una fila es 
una unica venta, no 
importa si el cliente 
compro mas de una 
unidad, en realidad es una 
transaccion, una venta 
unica realizada a un 
cliente individual. 


Etiquetas de fila p| ■ 

Consistencia 

El 1999 

32 % 

±2000 

27% 

El 2001 

27% 

±12002 

26 % 

£2003 

27% 

£2004 

27% 

£2005 

27% 

£2006 

27%, 

£2007 

27% 

£2008 

27%, 

£2009 

23 % 

£2010 

21 % 

£201 1 

21 % 

£2012 

21 %, 

£2013 

21 % 

£2014 

18% 

£2015 

15% 

Total general 

23% 


Figura 6.8- Reporte de Consistencia de Ventas 


NOTA 

Recuerda que la medida 
Sum of Precio de Venta se 
agrego anteriormente 
para anadir la funcion de 
resumen de forma 
explfcita. 


tSabes que estas viendo? Del total de dias con ventas en el ano, 
cuanto porcentaje corresponds a dias diferentes, por ejemplo, en 
1999 el 32% de las ventas se realizaron en dias diferentes, por lo 
que podrias concluir que necesitamos mas consistencia en las 
ventas diarias, de hecho, si se observan los dos ultimos anos te 
puedes percatar que la consistencia ha bajado aun mas, con esto 
podemos entrar a revisar aspectos internos, se pensaria en 
estrategias para incrementar la consistencia y asi impactar en 
mayores ingresos. Ahora, podemos agregar la siguiente medida: 

TABLA_Pedidos[Ventas por dia]:= 

[Sum of Precio de Venta] /[# de dias que hubo ventas] 


Podemos hacer el reporte mas robusto agregando esta ultima 
medida al area de filas. 
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Etiquetas de film T 

Consistencia Ventas 

por di'a 

+11999 

32 % 

$483 

+12000 

27% 

$513 

+12001 

27% 

$475 

+12002 

26% 

$521 

+12003 

27% 

$495 

+ 2004 

27% 

$462 

EH 2005 

27% 

$529 

HI 2006 

27% 

$552 

HI 2007 

27% 

$477 

HI 2008 

27% 

$491 

HI 2009 

23% 

$554 

HI 2010 

21 % 

$660 

HI 201 1 

21 % 

$592 

HI 2012 

21 % 

$627 

+12013 

21 % 

$637 

HI 2014 

IS % 

$703 

HI 2015 

15% 

$933 

Total general 

23% 

$576 


NOTA 

Vale la pena aclarar que 
cuando agregamos el 
campo Fecha de envio al 
area de filas este 
automaticamente hace las 
agrupaciones por anos, 
meses y trimestres en 
Excel 2016, si estas 
utilizando la version 2010 
o 2013 se debe hacer 
manualmente. Te dejamos 
el siguiente video por si no 
sabes como hacer esto. 


Figura 6.9- Reporte de Consistencia y Dias de Ventas 


jElegante no es asi! A parte de ver La consistencia de las ventas 
podemos observar a su vez el ingreso monetario que se ha 
obtenido por dia, es mas, podriamos anadir las medidas # de dias 
que hubo ventas y transacciones. 



Aarupacion 


Funciones Logicas 

Es practicamente pan de cada dia construir pruebas logicas para 
emplear calculos diferentes dependiendo del valor de una 
columna, incluso en Excel podemos darle una importancia 
sobrevalorada a la funcion Sl(). Con las condiciones logicas tambien 
interceptamos errores o las utilizamos para categorizar numeros o 
texto y delimitar segmentos. 
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NOTA 

No hay nada nuevo aquf, 
todas estas funciones son 
viejos conocidos de 
nosotros, solo que ahora 
los tenemos en el lenguaje 
DAX esperando a ser 
utilizadas en tablas 
dinamicas que es esa 
pizca de sabor explosivo 
adicional. 



La tabla acotninuacin nombra y describe Las funciones de la 
categoria logicas mas utilizadas en Power Pivot, todas ellas 
equivalentes con las de Excel. 



Funciones Logicas 

Funcion 

Description 

AND 

Verified si todos los argumentos son Verdaderos y 
retorna True (Verdadero) si lo son. 

FALSE 

Retorna el valor booleano False (Falso). 

IF 

Verified si una condicion se cumple y dependiendo 
de ello ejecuta una expresion. 

IFERROR 

Retorna lo especificado en el segundo argumento si 
hay un error. 

NOT 

Cambia de False a True o de True a False. 

OR 

Verified si alguno de los argumentos es verdadero, si 
lo es retorna True (Verdadero). 

SWITCH 

Retorna resultados diferentes dependiendo del valor 
en la expresion (Un IF Sofisticado) 

TRUE 

Retorna el valor logico True (Verdadero). 


Creemos un reporte de tabla dinamica con el modelo de datos en 
una nueva hoja de Excel. 


jToma Nota! 


Todas las medidas creadas en la tabla dinamica anterior, en el 
modelo de datos del libro para ser mas precisos, se mantlenen en 
todo nuevo reporte que se cree con dicho modelo de datos, un 
bondadoso beneficio de Power Pivot. jCrea, empaca y utiliza en 
cualquier lugar! 
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Creemos la siguiente Columna Calculada. 


[Abreviacion T. Compra] 

=IF( [Tipo de Compra]="Normar; 

"V"; 

IF([Tipo de Compra]="Devoluci6n";"D")) 


Solo una sencilla columna que acorta las palabras, una abreviacion, 
esto capta la esencia de la funcion IF, nada extrano, nada nuevo. 
Ahora la misma expresion, pero utilizando SWITCH. 


[Abreviacion T. Compra]=SWITCH( 

[Tipo de Compra]; 
"Normal"; "N"; 
"Devolucion'T'D" 

) 


NOTA 

El valor por defecto del 
ultimo argumento de la 
funcion IF es la funcion 
BLANKO mas adelante en 
este capftulo se habla de 
ello. 


NOTA 

Tenga en cuenta que la 
funcion IF es mas eficiente, 
si tiene una base de datos 
voluminosa (10 millones de 
datos mas o memos) utiliza 
IF. 


La funcion SWITCH es mucho mas facil de leer que su "melliza" IF, 
sobre todo cuando hay una gran cantidad de condicionales. 


jToma Nota! 



Si deseas probar multiples condicionales con la funcion SWITCH 
utilice TRUE() en el primer argumento y en los demas realiza las 
comparaciones usando los operadores logicos. 

=SWITCH(TRUE(); [Campol]="A" &&[Campo2]="B", "Resultado 7" 
[Campo1]="B" &&[Campo2]="C", “Resultado 2") 
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Funciones de Fecha y Hora 

La fecha, nunca puede faltar en una base de datos, asi mismo 
contamos con un grupo de funciones de fecha y hora, algunas de 
ellas muy similares a las de Excel. A continuacion, se describen 
algunas. 


NOTA 

Hay otro buen punado de 
funciones de fecha y hora 
(sin mencionar time 
Intelligence) que las que 
se muestran en la tabla, no 
obstante, se describen las 
que tienen mayor 
probabilidad de uso 
cuando se esta iniciando 
en el lenguaje DAX del 
modelo de datos. 


^ Algunas Funciones de Fecha y Hora 


Funcion 

Description 

DATE 

Retorna una fecha bien formateada. Ejemplo: 
=DATE(2008,I,-I5) retorna: diciembre 16, 2007. 

DATEDIFF 

Retorna las unidades en intervalo de fechas. 

DATEVALUE 

Convierte un texto en formato fecha. 
Ejemplo=DATEVALUE("8/112009") devuelve: 

August 1st of 2009 

DAY 

Retorna un numero de 1 a 31 que indica el dla del 
mes. 

HOUR 

Retorna un numero de 0 a 23 que indica la hora 
del dia. 

MINUTE 

Retorna un numero de 0 a 59 que indica el minuto 
de la hora. 

MONTH 

Retorna un numero de 1 a 12 que indica el mes del 
aho. 

TIME 

Convierte hora, minuto y segundo a formato. 

TIMEVALUE 

Convierte una hora en formato texto a formato 
fecha. 

TODAY 

Devuelve la fecha actual (Segun el Sistema). 

WEEKDAY 

Retorna un numero de ! al que indica el dia de la 
semana. 

YEAR 

Extrae el aho de una fecha. 

YEARFRAC 

Calcula la fraccion del aho dado dos fechas. 
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jToma Nota! 



Cuando agregamos un campo de fecha a alguna de las areas de 
colocacion, automaticamente se agrupan por ahos, meses y 
trimestres en Excel 2016, esto incide en Power Pivot creando 
columnas calculadas automaticamente en la tabla que contiene 
dicho campo, en nuestro caso el campo fecha de envio de la tabla 
pedidos. 


Funciones de Informacion 

Cada vez que necesitamos verificar o analizar eltipo de dato de una 
columna, las funciones de informacion vienen al rescate, aligual que 
la gran mayoria de las anteriores, son muy similares a las de Excel. 
Rescatamos las mas intuitivas en la tabla enseguida. 



Funciones de Informacion 

Funcion 

Description 

ISBLANK 

Verified si el valor es BLANKQ devolviendo TRUE si 
es afirmativo, de otro modo FALSE. 

ISERROR 

Verifica si el valor es un Error devolviendo TRUE si 
es afirmativo, de otro modo FALSE. 

1SEVEN 

Verifica si el valor numerico es par, devolviendo 

TRUE si es afirmativo, de otro modo FALSE. 

ISLOGICAL 

Verifica si el valor es Booleano devolviendo TRUE si 
es afirmativo, de otro modo FALSE. 

ISNOTEXT 

Verifica si el valor NO es tipo texto devolviendo 

TRUE si es afirmativo, de otro modo FALSE. 

ISN UMBER 

Verifica si el valor es de tipo numerico (Integer, 
Double, Currency) devolviendo TRUE si es 
afirmativo, de otro modo FALSE. 


NOTA 

Todas las funciones de 
informacion devuelven 
uno de dos valores. FALSE 
(Falso) o TRUE 
(Verdadero). 


ISTEXT 


Verified si el valor es de tipo texto devolviendo 
TRUE si es afirmativo, de otro modo FALSE. 







Capitulo 6 / Bienvenido al Pais de las Maravillas: Lenguaje DAX 



Funciones de Texto 

Casi todas las funciones de texto DAX son similares a las que estan 
en Excel, con algunas pocas excepciones. 



Algunas Funciones de Texto 

Funcion 

Description 

CONCATENATE 

Une dos cadenas de texto. 

EXACT 

Compara dos cadenas de texto, devuelve True si 
son identicas de otro modo devuelve False. 

FIND 

Devuelve la posicion de una cadena de texto dentro 
de otra. 

FIXED 

Redondea un numero a las posiciones decimoles 
especificadas como tipo texto. 

FORMAT 

Convierte un valor de acuerdo a un formato 
senalado. 

LEFT 

Retorna el numero de caracteres especificados de 
una cadena de texto empezando desde la 
izquierda. 

LEN 

Devuelve el numero de caracteres en una cadena 
de texto. 

LOWER 

Convierte todas las letras a minusculas 

MID 

Devuelve el numero de caracteres en una cadena 
de texto empezando desde una posicion indicada. 

REPLACE 

Reemplaza parte de una cadena de texto basado 
en un numero de caracteres especificados. 

REPT 

Repite un caracter dado un numero de veces 
senalado. 

SEARCH 

Devuelve el numero de posicion de un caracter 
especificado dentro de una cada de texto. 
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Continuacion 


Tabla 6.11 Algunas Funciones de Texto 


Funcion 

Description 

SUBSTITUTE 

Reemplaza un texto especificado por uno nuevo. 

TRIM 

Remueve todos los espacios en una cadena de texto 
exceptuando los espacios unicos que hay entre 
palabras. 

UPPER 

Convierte todas las letras a Mayusculas. 

VALUE 

Convierte una cadena de texto que representa un 
numero a tipo numerico. 


jToma Nota! 



Tambien se pueden distinguir un conjunto de funciones que nos 
permiten pasar de un tipo de dato a otro, denominaos a este grupo: 
Funciones de Conversion: CURRENCY (Transforma una expresion en 
tipo moneda), INT(Transforma una expresion en tipo entero), DATEy 
TIME toma los valores en sus parametros y devuelve en formato 
fecha, VALUE (Convierte un texto en numerico). 


Atributos de Buenas Funciones 


Antes de finalizar este capitulo vamos a ver una serie de conceptos 
para hacer nuestras formulas DAX robustas y claras. 


Robustez: Manejo de Errores 


NOTA 

Robustez: Cuan bien la 
formula DAX maneja 
errores, datos no validos y 
otros problemas 


Como en Excel una expresion puede contener valores invalidos, 
porque los datos a los que hace referencia tambien lo son, por 
ejemplo: division entre cero y la raiz de un numero negativo. A lo 
largo de los afios se han distinguido tres categories de errores, 


Claridad: Cuan facil es 
para alguien diferente al 
creador de la formula 
DAX, entenderla. 


estas son: 
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Categories de 
Errores 


Errores de 
Conversion 


NOTA 

jOJO! Si una fila resulta en 
error, entonces todos los 
demas valores de la 
columna seran errores 
independientemente si la 
operacion es valida para 
filas especificas, el hecho 
de encontrar un solo error 
propaga este mismo en 
toda la columna, por esto 
es necesario manejarlos e 
interceptarlos 
correctamente. 



■ Errores de Conversion 

■ Errores Matematicos 

■ Valores Vacios o Faltantes 


Como se discutio previamente los tipos de datos en DAX se 
convierten automaticamente al ser cargados al modelo de datos, ya 
que tambien cuentan con un sistema sofisticado de conversion 
cuando se operan columnas, mira en la siguiente tabla como las 
operaciones convierten los datos y cuales son las situaciones mas 
comunes que pueden generar error. 


imm 


Conversion con Operadores Automaticas 


Funcion 

Resultado 

Tipo 

"7"+28 

35 

Integer 

"7"&24 

724 

Texto 

7&24 

724 

Texto 

False+False 

0 

Integer 

False+True 

1 

Integer 

True+True 

2 

Integer 

False* False 

0 

Integer 

False*True 

0 

Integer 

True*True 

1 

Integer 

False+28 

28 

Integer 

DATE(2016; 1; 15) 

15/1/2015 

Date 

DATE(20l6;l;l5)+30 

14/2/2015 

Date 

Situaciones 

Invalidas 

"2+ 2 "+7 

#ERROR 


DATE("2016/1 /15") 

#ERROR 


“False”+28 

#ERROR 









El ADN DE Power Pivot 



Para evitar los errores de conversion es una buena practica 
asegurarse que el tipo de datos que esperamos de una columna 
sea el que necesitemos, para ello contamos con las funciones de 
conversion y la funcion logica IFERROR, por ejemplo: 


[Nueva Columna]=IFERROR( 

VALUE([Precio]) *VALUE([Unidades]); 
BLANK() 

) 


Vease la imagen para ilustrar la situacion para el manejo del error: 


[N ueva Col. 


A =IFERROR( 


VALUE([Precio])nALUE([Unidade5]); 

BLANKQ 



Esta es una de las 
situaciones en las cuales 
el sistema interno del 
modelo de datos no 
sabe como tratar y 
converts por lo tanto, 
devuelve un error. El solo 
hecho de que esta fila 
devuelva un error en el 
resto de la columna 
tambien apareceran 
errores, a pesar de que 
los demas son validos 
(Con IFERROR 
Solventamos la situacion) 


Figura 6.10 - Manejo de Error de Conversion 


Estos errores se producen porque matematicamente son 
desconocidos o carecen de significado, ellos son: 


Errores 

Matematicas 


■ Division entre cero 

■ Raiz Cuadrada de un numero negativo 

■ Logaritmo de un numero negativo 

/ mmw 



SlJJ 

m 
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Division Entre La primera situacion, division por cero, es bastante especial porque 

en lugar de devolver un error, retorna un valor especial: infinito (oo). 
Esto varia respecto a Excel quien devuelve #jDIV/0! Cuando una 
division por cero se ha realizado. Existe unafuncion llamada DIVIDE 
que nos permite realizar una division y a su vez definir que valor 
queremos retornar cuando encuentre division entre 0; en un capitulo 
posterior del presente texto la veremos en un escenario aplicado. 

La accion de Power Pivot para el manejo de division por cero puede 
parecer contra intuitivo, jy lo es!, sin embargo, en algunas ocasiones 
puede ser beneficioso, teniendo en cuenta que cuando se divide 
entre infinito (Un numero muy grande) retorna cero. 


Total Envios en el 
periodo) 



Negativo: 

Devoluciones 


En cuantos dias 
(Completos se 
hicieron los envios) 


= [Total Envios]/[Repartido en Dias] 


Cuanto del 
presupuesto de envio 
hubiera correspondido 
por cada envio. 


Total Evios 1 

Total Evios: ( 

Envio 5 por Dia 

Presupuesto ^or E... 1 

-7 

(Seleccionartodo) [ 

-1.4 

-357.142857142857 [ 

57 

7 

8. M285714285714 

61.4035087719298 

5 

0 

CO 

0 

80 

7 

1 1.4285714285714 

43.75 


Figura 6.11- Ejemplo Con Infinito 


Pausemos un Momento 



El ejemplo anterior con infinito es algo tonto, lo sabemos, pero con 
esto podemos pensar en una manera de trabajo alterna a la que 
hemos estado acostumbrados en Excel iPuedes encontrar una 
situacion en tu trabajo en el cual el manejo con infinito ayude? 



Ir 
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Hay ciertas situaciones en las que manejar infinitos y ceros llevan 
a indeterminaciones matematicas (NaN en Power Pivot), es decir, no 
se sabe que puede pasar en dichos escenarios dado que puede dar 
un valor u otro (fluctuar entre limites). Por lo anterior decimos que 
son indeterminados, ya que no contamos con la informacion 
suficiente para determinar cual seria un valor exacto. El mas comun 
de las indeterminaciones es la division de cero entre 0, que 
ocasionalmente puede aparecer. Hay otras que son muy poco 
frecuentes pero que dejamos en la siguiente tabla por si en algun 
momento te encuentras con ellas. 



Indeterminaciones Matematicas 


Funcion 

Resultado 


010 

NaN 

Indeterminado 

oo/oo 

NaN 

Indeterminado 

00_00 

NaN 

Indeterminado 

o 

■* 

8 

NaN 

Indeterminado 

0° 

NaN 

Indeterminado 

0°o 

NaN 

Indeterminado 

l°o 

NaN 

Indeterminado 


NOTA 

Nan no es un error en 
Power Pivot, es un tipo 
especial de valor que 
podemos manipular a 
nuestra conveniencia, por 
esto si aparece un Nan en 
una fila no dana la 
columna completa 

solamente ponen Nan en 
la celda especifica. Por 
ejemplo, si somos 

conscientes de que 
valores Nan estan 

apareciendo en la 
columna, podemos utilizar 
un condicional o la 
funcion SUBSTITUE para 
establecer que aparezca 
BLANK u otro valor que se 
ajuste a nuestro escenario. 


Por otra parte, tratar de determinar la raiz cuadrada par de un 
numero negativo, si arroja un error, y ello dana la columna 
completa, esto es facil de prevenir. 

[Viabilidad]=IF( 

Datos[Determinante]>0; 
SORT(Datos[Determinante]); BLANKQ 


Rafz Cuadrada 
Negativa 
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Logaritmo 

Negativo 


Valores Vados o 
Faltantes 


NOTA 

BLANK no es un numero 
ni nada por estilo, es un 
tipo especial de valor, para 
manejar esta condicion de 
faltante. 



AL igual que La raiz cuadra negativa devueLve un error, cuando se 
trata de determinar eL Logaritmo de un numero negativo se estropea 
toda La columna, utiLiza un condicional muy simiLar aL anterior para 
interceptar eL error y no obtener resultados inesperados. 

Los vaLores vados son datos faLtantes o desconoddos en La base de 
datos. EL lenguaje DAX del modelo de datos no Los trata como un 
error por Lo que no dana toda La columna si llegan a aparecer, para 
el Lenguaje DAX es un tipo especial de valor, algo simiLar a Lo que 
sucede con el tipo especial NaN. 

Para el modelo de datos una celda vacia, valor faltante o valor en 
bianco es lo mismo: lo identifica con BLANK, el cual es una forma 
de representar esta condicion especial de ausencia de valor. 

Como pudimos ver en los ejemplos anteriores contamos con una 
funcion BLANI<() para retornar este tipo especial de valor, el cual es 
diferente de una cadena de caracteres vacia ("") ya que cada uno 
tiene comportamientos diferentes. Podemos sonar insistentes, 
pero es importante que no se nos olvide. 


jToma Nota! 


Cada vez que desee devolver un valor vacio utilice la funcion BLANKO, 
tal cual como se mostrd en los ejemplos anteriores, de ningun modo 
utilice expresiones como: "" o " BLANKO es nuestro amigo, 
acostumbremonos a utilizarlo. 
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Dejamos la siguiente tabla para que puedas consultar agilmente el 
comportamiento que tiene BLANK cuando se hacen operaciones 
consigo misma o con otro tipo de valores. 



Comportamiento de BLANK y las distintas operaciones 


o 

E 

</> 

z 


o 

m 


c 

o 


U 


{/) 

o 

u 

% 

E 

L 

< 


c 

o 


u 

"D 

c 

o 

U 


Operation 

Resultado 

BLANK() + BLANK() 

BLANK() 

BLANK() - BLANK() 

BLANK() 

BLANK() * BLANK() 

BLANK() 

BLANK() / BLANK() 

BLANK() 

BLANK() || BLANK() 

False 

BLANK() && BLANK() 

False 

BLANK() A BLANK() 

#ERROR 

BLANK() & BLANK() 

BLANK() 

7*BLANK() 

BLANK() 

28/BLANK() 

OO 

0/BLANKO 

Nan 

7*BLANK() 

BLANK() 

28+BLANK() 

28 

7-BLANK() 

7 

BLANK()>BLANK() 

False 

BLANK()>=BLANK() 

True 

BLANK()<BLANK() 

False 

BLANK()<=BLANK() 

True 




No es necesario aprenderse de memoria La tabla, mas bien es una 
nocion general de su comportamiento, ademas, se ha escrito a 
modo de resumen para que de esta manera cada vez que tengas 
aLguna duda del comportamiento de BLANK puedes acudir aqui 
rapidamente. 

j 
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Claridad: Optimizar Lectura 

Cuando creamos una formula DAX larga es una buena practica 
acostumbrarnos a darle una forma que sea legible, no solamente 
para un tercero, sino tambien para nosotros mismos, ya que 
despues de un tiempo de haberla desarrollado y necesitemos 
ajustarla, modificarla o reciclara, sea sencillo y rapido. 

Tome el siguiente ejemplo de una formula DAX con una extension 
bastante considerable. 


NOTA 

Vease el Anexo C para 
conocer la utilidad Online: 

DAX Formatter. 

El DAX Formatter es una 
herramienta creada por el 
equipo de SQLBI que nos 
permite de manera agil 
dar formato a formulas 
largas en Power Pivot, 
siguiendo las reglas que se 
listan en la pagina 
siguiente. 


Mediana 2010-2013:=(MINX (FILTER( VALUES ( 
TABLA_Pedidos[Costo Total]);CALCULATE (COUNT ( 
TABLA_Pedidos[Costo Total] );TABLA_Pedidos[Costo 
Total]<= EARLIER ( TABLA_Pedidos[Costo Total]) )> COUNT ( 
TABLA_Pedidos[Costo Total]) / 2 ); 

TABLA_Pedidos[Costo Total])+ MINX (FILTER (VALUES ( 
TABLA_Pedidos[Costo Total] ); 

CALCULATE COUNT ( TABLA_Pedidos[Costo Total] 
);TABLA_Pedidos[Costo Total] 

<= EARLIER ( TABLA_Pedidos[Costo Total])) > ( COUNT 
(TABLA_Pedidos[Costo Total]) -1) / 2 ); 
TABLA_Pedidos[Costo Total])) / 2 


A parte de verse tetrico, es muy dificil de entender, llegando a los 
horizontes de lo imposible, no obstante, la idea es poder darle una 
presentacion mas apropiada. A continuacion, se presentan una 
serie de pautas que se han ido estandarizando en el medio para 
clarificar las formulas DAX. Nosotros no hemos definido estas 


reglas, han sido los diferentes usuarios de Power Pivot que con el 
tiempo han llegado a estas convenciones y se han ido extendiendo 
al pasar de los anos. 
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Reglas para la presentacion de formulas DAX optima. 


■ Siempre incluir un espacio despues de un parentesis. Regia 1 

■ Poner un espacio antes y despues de un operador sin Regia 2 

importar su categoria. 

■ Si se tiene que dividir una expresion en multiples lineas, Regia 3 

poner el operador al principio de la nueva linea. 

■ Una funcion que se ha divido en multiples lineas debe Regia 4 

siempre tener sus distintos argumentos en lineas diferentes. 

■ Omitir espacio entre el nombre de la tabla y el nombre de la Regia 5 

columna. 

■ Utilizar las comillas simples cuando sea estrictamente Regia 6 


necesario, es decir, cuando el nombre de una tabla contenga 
espacios. 


■ Omitir el nombre de la tabla cuando se esta haciendo Regia 7 

referencia a una medida. 

■ Poner un espacio despues de un argumento si estos estan Regia 8 

en la misma linea. (Shift + Enter) 

■ Siempre utilizar el nombre de las tablas cuando se haga Regia 9 

referencia a una columna 

■ Poner una funcion en la misma linea solamente si tiene un Regia 10 

unico argumento. 

■ Si una funcion esta escrita en mas de una linea, utilice Tab Regia 11 


para indexar, asi mismo, los parentesis de apertura y cierre 
deben estar alineados. 

Tomemos la formula DAX anterior y brindemosle el formato 
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NOTA 

La funcion es mucha mas 
clara ahora. El uso de las 
funciones y sus distintos 
argumentos se pueden 
identificar facilmente 
agilizando su 

interpretacion, si bien, 
entender la funcion 
completamente con el 
conocimiento adquirido 
hasta ahora no es posible, 
es simplemente cuestion 
de entender y profundizar 
en las funciones DAX 
avanzadas que seran 
tratadas en un capitulo 
posterior. 


TABLA_Pedidos[Mediana 2010-2013]:=( 

MINX ( 

FILTER ( 

VALUES (TABLA_Pedidos[Costo Total] ); 

CALCULATE( 

COUNT (TABLA_Pedidos[Costo Total] ); 
TABLA_Pedidos[Costo Total] 

<= EARLIER ( TABLA_Pedidos[Costo Total]) 

) 

> COUNT ( TABLA_Pedidos[Costo Total]) / 2 

); 

TABLA_Pedidos[Costo Total] 

) 

+ MINX ( 

FILTER ( 

VALUES (TABLA_Pedidos[Costo Total] ); 
CALCULATE( 

COUNT (TABLA_Pedidos[Costo Total] ); 
TABLA_Pedidos[Costo Total] 

<= EARLIER ( TABLA_Pedidos[Costo Total]) 

) 

> ( COUNT (TABLA_Pedidos[Costo Total]) -1) / 

2 

); 

TABLA_Pedidos[Costo Total] 

) 


jToma Nota! 



Para facilitar la escritura de funciones DAX extensas con buenos 
estandares sigue estos Tips: 

■ Si quieres hacer el texto mas grande ya sea en la barra de 
formulas DAX o el cuadro de dialogo, utiliza Ctrl + el Scroll del 
mouse. 

■ Para artadir nuevas tineas utiliza el ataj'o de teclado Shift + Enter. 
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Algo mas Sobre Categorias 

Habras notado a lo Largo del capitulo que Las funciones conocidas 
como SUM, MAX Y PROMEDIO, por mencionar aLgunas, tienen un 
sufijo A o X <■ A que se debe? 

Funciones con Sufijo A 

Las funciones con un sufijo A estan disponibLes para manejar 
vaLores de tipo texto, en cuyo caso Los toma como cero (0). Estas 
funciones si se apLican a columnas de texto no devueLven error 
sino 0, aLgunos ejempLos: AVERAGEA, MAXA, etc. 

Funciones con Sufijo X 

Las funciones con un sufijo X son bastante especiales y poderosas 
en eL Leguaje DAX, para entenderlas apropiadamente se requiere 
de cierta teoria previa por lo que se estudiaran mas adelante. 

El Siguiente Paso 

Las funciones y conceptos vistos en este capitulo son unicamente 
la punta del iceberg del lenguaje DAX, todas las posibilidades y 
caminos que nos proporcionan simplemente son abrumadoras, 
pero, fascinante e impresionante, el proximo capitulo representa 
un "nuevo comienzo" donde empezamos a sumergirnos para 
conocer este inmenso tempano de opciones, analisis, toma de 
decisiones y mas. 




La Presente Pagina se ha dejado en Blanco de forma deliberada. 




CapituLo 7 


Back-Office, Contextos: DAX Engine 

Detras de Camaras 




Capitulo 7 / Back-Office, Contextos: DAX Engine Detras de Camaras 



Nova Genesis 

Hasta aqui hemos venido forjando los cimientos primordiaLes y 
esenciales en Power Pivot, tenemos las bases solidas en la creacion 
de los tipos de calculos personalizados: Medidas y Columnas 
Calculadas, asi como nociones basicas y generales pero claras 
sobre el Lenguaje DAX. 

Este capitulo supone un punto de inflexion, una nova genesis 
(Nuevo comienzo) donde el crecimiento toma un giro vertiginoso 
pero excitante para empezar a volvernos unos verdaderos magos 
en el lenguaje DAX e inteligencia de negocios como consecuencia. 
Es entonces el escenario indicado para levantar los pilares teoricos 
que nos llevaran al siguiente nivel. En definitiva, hemos construido 
todo lo basico, sin embargo, para poder continuar con nuestra 
edificacion en el modelo de datos en Power Pivot y tener acceso a 
las "funciones de elite" y tecnicas sorprendentes, debemos hacer 
una parada estrategica para construir estos pilares que soporten un 
conocimiento superior y profundo. 

iCuales son estos pilares?, Te estaras preguntando. 
Fundamentalmente debemos entender al cien por ciento como el 
DAX Engine determina los valores de las distintas medidas en una 
tabla dinamica, y como es el comportamiento preciso de las 
columnas calculadas; de lo previo es seguro que tenemos una 
compresion intuitiva, de hecho, hemos dedicado unos cuantos 
parrafos a ello, no obstante, clarificar y estructurar como funciona 
el Back-Office de Power Pivot, hace las veces de la piedra filosofal 
para convertir nuestros datos en oro puro de informacion. 
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Los pilares a los que nos referimos son los: Contextos, estos son 
quienes nos permiten hacer analisis dinamicos en donde Los 
resultados de los calculos personalizados cambian reflejando La 
configuracion del reporte, tabla o formula. 


Existen varios contextos, los mencionamos continuacion para ir 
teniendolos en cuenta de entrada. 

■ Filter Context | Contexto de Filtros 

■ Query Context | Contexto de Consulta 

■ Row Context | Contexto de Fila 

■ Evaluation Context | Contexto de Evaluacion 

Para entenderlos vamos a seguir el proceso detras de camaras que 
realiza el DAX engine para hallar las medidas. 


NOTA 

Probablemente no nos 
refiramos a los distintos 
contextos con su nombre 
traducido al espanol, es 
mas podemos aseverar 
que de ahora en adelante 
los llamaremos por su 
nombre en ingles. 
Costumbre mas que otra 
cosa. 


Pausemos un Momento 



Podemos decirte con total sosiego que este capttulo y los posteriores 
no son nada complejos, a pesar de entrar en el mundo de lo 
avanzado, mas bien, lo que si requiere es de especial atencion y un 
buen cafe para estar activos. 


Etapas para el Calculo de Medidas 

El DAX engine sigue un proceso ordenado y logico para calcular las 
expresiones DAX especificadas en una medida, el siguiente 
diagrama de flujo ilustra el proceso mencionado: 
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Diagrama de Flujo 

PARA CADA CELDA en el cuerpo de la tabla dinamica haga: 


NOTA 

El diagrama de flujo que 
representa el proceso de 
calculo para medidas en 
este momento NO senala 
que debamos entenderlo, 
puesto que es nuestra 
tarea de ahora en 
adelante, sin embargo, 
tomalo como la guia 
turfstica para el recorrido 
que vamos a emprender, 
sientete libre de volver 
cada vez que necesites 
para adherir este proceso 
a tus conocimientos, la 
idea es volverlo tan 
intuitivo y natural para 
nosotros como si fuera la 
tabla del 2, ademas, este 
diagrama se provee en el 
compendio de archivos 
para que acudas a el 
agilmente cada vez que lo 
necesites una vez dejes 
este libro. 


Incio 



Fin 
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Etapa 1: Determinar el Query Context 

Arrancaremos logicamente por indagar la etapa uno para 
interpretar que sucede alii, por eso vamos a crear un reporte de 
tabla dinamica con la siguiente configuracion: Sumo of Predo de 
Venta (Medida Explidta) al area de valores, campos Descuento (%) 
de la tabla Descuentos al area de filas, campo Tipo de Compros de 
la tabla pedidos al area de columnas, el campo Pais de la tabla 
Pedidos al area de filtros, finalmente crear un Slicer del campo 
Producto (s) de la tabla SKU Productos. 


Pai5 


| Ecuador 


Sum of Precio de Venta Etiquetas de columna I 


Etiquetas defila 


0 

0.15 

0.2 
| 0.25 


Devolution 


Normal Total general 


121.16 


193.856 


1332.7 > 
102.98 > 
630.03 l 


>— *c 


136.305 


1453.92 

102.986 

823.888 

181.74 


0.35 ^ 



236.262 236,262 


Total general 


45 1 .32 1 2347.475 2798.796 


Producto(s) 







V- 


Sabaton: The Art of War + Sabato... Sears & ] 

[e man sky's University Phy... 

a 

.- 

Sears & Zemansky's University Phy... 

The Dark Knight 


The Dark Knight Rises 

99 Must-Have Mozart Masterpieces 






V 


Figura 7.1- Tabla Dinamica para Estudiar el Query Context 


La idea es entender como el modelo de datos llega a cada uno de 
los valores en la tabla dinamica, para ello debemos recalcar, otra 
vez, que cada valor se calcula individualmente y completamente 
independiente de los demas, quiere decir esto que el proceso de 
calculo de un valor en el cuerpo del reporte de tabla ... 
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Deteccion de 
Coordenadas 


... Dinamica no influye de ninguna manera en el proceso de 
determinacion de otro valor. Por lo anterior vamos a tomar el valor 
136.305 del reporte en la figura anterior, por el momento. La etapa 
uno se "subdivide" en tres sub etapas: 

■ Deteccion de Coordenadas 

■ Aplicacion de Coordenadas 

■ Determinacion del Query Context 

Todos estamos de acuerdo que el valor 136.305 concierne 
unicamente a los elementos: 0.25 porque asi lo senala la fila 
correspondiente en la tabla dinamica, tambien corresponde 
solamente a los elementos Devolucion dado que asi lo indica el 
reporte en la columna, por otra parte, sabemos que solo pertenecen 
al elemento Ecuador ya que se ha filtrado de esta manera y, para 
terminar, el Slicer ensefia que solamente los elementos The Dark 
Knight. Este grupo de parametros son las coordenadas del query 
context, es decir los filtros a aplicar en las diferentes tablas. 
Observa los elementos en azul de la figura anterior. 


Aplicacion de 
Coordenadas 


Una vez se han detectado las coordenadas, se deben tomary aplicar 
en las tablas correspondientes, por ejemplo, en la tabla pedidos: 


Dos de las coordenadas 

i 

Tipo de Compra |,»^j Vh 

3 

3 

3 

3 

3 

3 

3 

H Pais EJ Ciudad 

corresponden a campos en la 
tabla pedidos, en cuyo caso 
se aplican como filtros, es 


Devolucion C. 

N. 


i 



2 


... Ecuador Quito 


Devolucion j C. 

N. 


1 

... 

... 

1 

... 

... Ecuador Quito 

decir, para el campo Tipo de 
Compra se aplica Devolucion 
y para el campo Pais Ecuador. 


Devolucion C. 

N. 

... 

1 

... 

3 

1 

... 

... Ecuador Quito 


Devolucion C. 

N. 


1 

.... 

... 

3 

... 

... Ecuador Quito 


Figura 7. 2 - Aplicacion de Coordenadas 
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Se ha ilustrado unicamente la tabla Pedidos, a pesar de ello, los 
otros campos tambien se aplican a sus respectivas tablas. 


El conjunto de filas y columnas involucradas despues del filtro Query Context 

corresponde al Query Context. 


jToma Nota! 



OK, jTE HEMOS ENG AN ADO!, la etapa uno NO tiene sub etapas 
como las descritas, en realidad, solamente hace la detection de 
coordenadas, sin embargo, hitimos el ejertitio con las demas sub 
etapas para entender cuales son las coordenadas y cual el contexto, 
ademas, las sub etapas si se aplicaran, pern mas adelante en el 
proceso (Diagrama de Flujo). 


Etapa 2: ^Existe Algun Tipo de Constrain? 


Sin duda, llegamos a un ingrediente crucial. Para entender por que, 
resumamos las coordenadas del query context de la celda 
correspondiente a el valor: 136.305 del reporte en la figura 7.1 
para tenerlas presentes. 

■ Descuentos[Descuento]=0.25 

■ TABLA_Pedidos [Categoria de Descuentos ]="Devoluci6n" 

■ TABLA_Pedidos[Pais]= "Ecuador" 

■ 'SKU Productos'[Producto(s)]= "The Dark Knight" 

Hasta hace unos anos era imposible y de algun modo ilogico alterar 
las coordenadas del query context; para aclarar esto veamos y 


NOTA 

La traduccion en espanol 
para la palabra para 
Constrains serfa 

Restricciones, por lo que 
podria leer esta etapa 
como: iExiste algun tipo de 
Restriction para el Query 
Context? Aquf en el libro 
siempre nos referimos a 
este termino en ingles. 


analicemos la siguiente tabla dinamica meticulosamente. 
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NOTA 

Este reporte de tabla 
dinamica lo construimos 
de manera que quedara 
muy similar al anterior, 
solamente se movio el 
campo Tipo de Compra 
de la tabla Pedidos del 
area de filas al area de 
filtros, donde se filtro por 
devolucion y asi tener el 
valor 136.305., tambien se 
agrego la Medida: 
Colombia Suma Precio de 
Venta, en la pagina 
siguiente se muestra 
como crearla. 


Constrains 


Pais Ecuador g El query context para esta medida y valor es 

Tipo de Compra Devolucion g exactamente el mismo que las coordenadas 

listadas en la pagina anterior. 


1 Etiquetas de fila Q Sum 

of Precio de Venta Colombia Suma Precio 

de Venta 1 

0 

121.16 

$242 

0.2 

193.856 

$194 

0.25 

136.305 

$45 

Total general 

45 1 32 1 

$482 


Producto(s) ^ 


Sab atom The Art of War + Sabato... 

Sears &Ze man sky's University Phy... 

Sears & Ze man sky's University Phy... 

The Dark Knight 

The Dark Knight Rises 

99 Must-Have Mozart Masterpieces 


Figura 7.3 - Tabla Dinamica para Estudiar Constrains Context 


^Estas viendo lo mismo que nosostros? A pesar de que las 
coordenadas del query context para el valor $45 son las listadas en 
la pagina anterior, la Medida: Colombia Suma Precio de Venta, senala 
que se esta filtrando por el pais Colombia, al menos eso dice su 
etiqueta de columna; visto de otra manera, la medida anterior 
agrega la coordenada: TABLA_Pedidos[Pais]= "Colombia", esto es 
precisamente un Constrain, es decir, alteraciones en las 
coordenadas del query context. Es eso posible? Por supuesto que 
si, y vamos a ir a ello enseguida. 



Pues bien De donde salen estas alteraciones? Y iComo 
identificarlos?, de hecho, es bastante facil ya que quien indican si 
hay constrains son las funciones en la expresion DAX de la medida. 
Se que te estaras preguntando <- Como se cudles funciones? y icudles 
son las coordenadas?, vamos ir respondiendo estas preguntas poco 
a poco, pero para identificar si hay constrains o no lo unico que 
debemos hacer es plantearnos la siguiente pregunta: 

wmww' 
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lLa expresion de la Medida contiene por lo menos una de las 
siguientes fund ones ?: 

NOTA 



Funciones que ALteran el Query Context (Constrains) 


Funciones 

Familia 

CALCULATE 

Calculate 

CALCULATTABLE 

Calculate 

ALL 

All 

ALLEXCEPT 

All 

ALLSELECTED 

All 

FILTER 

Filter 


* Hay muchas mas funciones que alteran el query context (Funciones de 
“alteration”), sin embargo, estas son las principales. 


Si es asi; tenemos constrains y nuestro diagrama de flujo toma el 
camino del sf en esta etapa, sino, no hay Constrains toma el camino 
del noyendo a la etapa cuatro directamente. 

Los constrains alteran las coordenadas de tres maneras: 

■ Agregan nuevas coordenadas 

■ Modifican coordenadas existentes 

■ Remueven coordenadas existentes 


A nosotros nos gusta 
agrupar las funciones que 
alteran el query context en 
tres familias: la familia 
Calculate, la familia All y la 
familia Filter (que solo tiene 
un integrante), lo hacemos 
asi no solo porque es 
buena tactica para 
memorizar estas 

funciones, sino tambien 
porque nos permite 
recordar que tipo de 
alteracion le realizan al 
query context. 

Tambien nos gusta llamar 
a todos estas Funciones 
de "alteracion". 

Adicionalmente estas 
funciones son un sub 
conjunto de un grupo mas 
grande de funciones, mas 
adelante veremos por 
que; por ahora 
recordemos que hemos 
bautizado a estas familias 
de funciones como: 
funciones de "alteracion". 


Cada una de las "familias" de funciones que categorizamos en la 
tabla anterior ejecuta una de las alteraciones mencionadas: 


■ Familia Calculate -> Modifica y/o Agrega Coordenadas 

■ Familia All -> Remueve -Ingnora- Coordenadas 
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Las constrains o restricciones (alteraciones en el query context) les 
da un poder y majestuosidad a Las expresiones DAX para hacer 
inteligencia de negocios que es casi mistico, en eL proximo capitulo 
estaremos profundizando ampliamente en estas alteraciones, por 
el momento vamos a ver una infima parte de una de las 
alteraciones: Modificar Coordenadas con CALCULATE. 

Hasta aqui no hemos hablado de la funcion CALCULATE, la 
estudiaremos intensamente en el siguiente capitulo, por el 
momento miremos su sintaxis y fundamentos: 


Sintaxis funcion 
CALCULATE 


=CALCULATE(<expresion>; filtrol; filtro2;...) 


NOTA 

Ten presente que en esta 
etapa no se calcula o se 
ejecuta la expresion, en 
lugar a ello lo que hace 
Power Pivot es chequear 
de manera general la 
sintaxis. 


En el primer argumento <expresion> de la funcion CALCULATE se 
debe poner la funcion o expresion DAX que deseamos que se 
calcule, por ejemplo, si colocamos SUM(TABLA_Pedidos[Precio de 
Venta]) que es lo mismo que [Suma of Precio de Venta], porque se 
creo previamente como medida explicita, entonces le estamos 
diciendo a CALCULATE que realice la suma en la columna Precio de 
Venta en el contexto que resulta despues de aplicar los Constrains 


Del segundo argumento en adelante de La funcion CALCULATE 
corresponden a los filtros, estos filtros son las coordenadas para 
restringir el query context (Constrains), bien sea por modificacion 
o agregacion de los mismos, para ser mas precisos veamos la 
formula DAX de la medida: Colombia Suma Precio de Venta de la 
tabla dinamica anterior: 
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TABLA_Pedidos[Colombia Suma Precio de Venta]:= 
CALCULATE( [Suma of Precio de Venta]; 

TABLA_Pedidos[Pais]= "Colombia") 


Hagamos un parentesis y tomemos la celda con el valor $45 del 
reporte presentado en la figura 7.3, aqui estamos cambiando la 
celda a analizar, que era el valor 136.305 de la tabla dinamica de 
la figura 7.2. 

Recuerde que el proceso de calculo para cada valor en el cuerpo 
de la tabla dinamica se hace de manera independiente y ningun 
proceso afecta a otro, es decir, el valor 136.305 no afecta de 
ninguna forma la manera en como se calcula el valor $ 45. Sonamos 
repetitivos en ello, pero no queremos dejar cabos sueltos y 
seremos bastante cautelosos para minimizar la posibilidad de que 
se preste para confusiones, ya que, si bien son conceptos faciles, 
son criticos para entender aspectos avanzados, tenerlo en mente 
todo el tiempo catapulta nuestro aprendizaje para poder llegar a 
dominar con total maestria el lenguaje DAX. 

El cambio de escenarios (Valor de la celda y medida a analizar) lo 
hacemos para entender la teoria y escarbar un poco en el Constrain 
con la funcion CALCULATE. Dicho esto, visualizamos el query 
context del valor $45 para la medida Colombia Suma Precio de 
Venta, junto con el Constrain que provee la funcion CALCULATE en 
su segundo argumento. 
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Coordenadas del Query Context para el Valor 
$45 de la tabla dinamica de la figura 7.3 y 
Constrains de la Medida Colombia Suma of 
Precio de Venta 


Estas dos coordenadas son 
iguales porque hacen 
referencia a el mismo campo 
en la misma tabla, 
independientemente de que 
elemento este indicado. 



Coordenadas del Query, 

Context 

Descuentos[Descuento]=0.25 


Constrains 


Pedidos [Categori'a de 
Descuentos]= 
’’Devolucion” 

Pedidos[Pais ]=”Ecuador” 

‘SKU Productos’[Producto(s)]= 
’’The Dark Knight” 


Pedidos[Pai's]=”Colombia’ 


Como se puede apreciar hay un conflicto de intereses en el filtro 
de pais de la tabla pedidos, no obstante, lo que pasa es que a partir 
de las coordenadas del query context y de los constrains se crea un 
nuevo conjunto de coordenadas para construir un contexto 
Filter Context definitivo, denominado: filter context La construccion de filter 

context depende de la funcion de "alteracion" tabla 7.1 que este en 
la medida. 


Etapa 3: Construir Filter Context 

El filter context emerge de aplicar los constrains al query context. 
Adicionalmente sabemos que tenemos tres de tipos de constrains o 
alteraciones (Modificacion, Agregacidn o Remocidn). Estas estan 
asociadas a un grupo especifico de funciones cuyo tipo de 
alteracion depende de la "familia" a la cual pertenezca, Vease la 
tabla 7.1. Por lo anterior debemos estudiar estos tres tipos de 
constrains y las funciones que la acompanan. 
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Si la expresion DAX de la medida tiene alguna de las funciones de 
la familia Calculate nos encontramos ante un tipo de constrains 
que modifica y/o agrega coordenadas. 


Constrain 
Modificacion 
y/o Agregacion 


tComofunciona? Porel momento analicemos lafuncion CALCULATE 


Todos los filtros (coordenadas) que se hallan indicado a partir del 
segundo argumento de la funcion CALCULATE son constrains para 
el query context, como vimos hace un momento, si dos 
coordenadas son comunes, entonces la coordenada del Constrain 
sobre escribe la coordenada del query context, Asi: 



Sobrescribir Coordenada: Modificacion 


COORDENADAS 

COMUNES 

Decimos que las 
coordenadas son 

comunes si, ambas 
apuntan al mismo campo 
de la misma tabla 
independientemente si 
hacen referenda al mismo 
elemento. 


Coordenadas del Query, Constrains 

Context 


Descuentos[Descuento]=0.25 


Pedidos [Categoria de Descuentos]=”Devo/uc/on” 


Pedid<g^«j^g:uador” 

Pedidos[Pai's]=”Co/omb/a” 

‘SKU Productos’[Producto(s)]= ’’The Dark Knight” 



El nuevo arreglo de coordenadas resultado de aplicar el constrains 
al query context pasaria a ser el filter context, quedaria asi: 



Filter Context para el valor $45 


Coordenadas del Filter Context 

Descuentos[Descuento]=0.25 

Pedidos [Categoria de Descuentos]=”Devo/udon” 
Pedidos[Fechas de LLegada]=”0//04//4” 
‘SKU Productos’[Producto(s)]= ’’The Dark Knight” 
Pedidos[Pai's]=”Co/omb/o” 
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Constrain 

Remocion 


Si una coordenada de un constrain no es comun con ninguna en eL 
query context, entonces pasa a ser parte del query context 
directamente. 

La familia de funciones ALL nos permiten remover coordenadas del 
query context sin necesidad de reemplazarlo con otro, 
simplemente elimina la o las coordenadas de lleno, por otra parte, 
filter realiza un tipo de modificacion bastante especial en el query 
context 

Por el momento no entraremos en mas detalle sobre los constrain, 
ya que no queremos hacer el capitulo mas denso, pues el objetivo 
es entender como Power pivot llega a cada valor en el cuerpo de la 
tabla dinamica: 



jToma Nota! 

Aunque veremos las demas constrains y sus funciones asociadas en 
el proximo capitulo, ten en cuenta que solamente la funcion 
CALCULATE es capaz de hacer modificaciones en el query context 
(contexto de consulta). 


Retomando el ejemplo, repasemos como quedo el filter context: 



Filter Context del Valor $45 del reporte de la figura 7.3 


Filter Context de 
la Medida 
Colombia Suma of 
Precio de Venta 


Coordenadas del Filter Context 

Descuentos[Descuento]=0.25 

Pedidos [Categori'a de Descuentos]= ’’Devolucidn” 
Pedidos[Pais]=”Co/omfa/a” 

‘SKU Productos’[Producto(s)] = ’’The Dark Knight” 
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Etapa 4: Aplicar Filter Context y Propagar (Si Aplica) 

^Recuerdas la sub etapa 2 de la etapa 1? pues bien, aqui es donde 
sucede verdaderamente, es decir, las coordenadas aplican los 
filtros en las tablas correspondientes. Siguiendo las coordenadas 
del valor $45 del reporte de la figura 7.3, podemos visualizarlo asi: 


Coordenadas del Filter Context 

-0 Descuentos[Descuento]=0.25 


Pedidos [Categoria de Descuentos]=”Devo/uc/dn’ 
Pedidos[Pai's]=”Co/omb/o” 9 _ 



Cada coordenada se 
aplica como filtro en 
su tabla 

correspondiente. 


‘SKU Productos’[Producto(s)]= ’’The Dark Knight 


Descuento (%) 

:r 

Categoria de Desc... n o 

o 

0.25 

Balck Fnaday 


Tabla Descuentos \ Tabla de Busqueda 


BO 2 


T 1 Prodycto(s) 


The Dark Knight 


Tabla SKU Producto(s) | Tabla de Busqueda 


o 

D 

3 

o 


Q) 

OL 

3 

o 


I Numero de Pedido: 1 

y 1 

Categoria de Desc... 'n C 

Precio de Venta Q 

uIW 

n 

| Pais | BOB 

| (Sdeccionar todo) 

XB0I 

Non 

444.06 



ColomR^ 

Ne< 

Devolucion 

CB0I 

Non 

444.06 

1 

.. . .. 


Colombia 

Me. 

Devolucion 

CB0I 

Non 

444.06 

1 


Colombia 

Me. 

Devolucion 

CB0I 

Non 

666.09 

1 


|Colombia | 

| Me. 

Devolucion 

CBOI 

Non 

666.09 

1 

■j ■ " 


Colombia 

Me. 

Devolucion 

CB0I 

Non 

666.09 

. 1 . .. 


Colombia 

Me. 

Devolucion 

CBOI 

Non 

666.09 

|. 


Colombia 

Me. 

Devolucion 

CBOI 

Non 

666.09 

. 


Colombia 

Me. 

Devolucion 

CBOI 

Non 

666.09 

. 1 . .. 


Colombia 

Me. 

Devolucion 

CBOI 

Non 

666.09 

1 

1 


Colombia 

Me. 

Devolucion 

CBOI 

Non 

666.09 

1 


Colombia 

Me. 


rum 

Kl^.n 

444 no 




M~. 


Esta columna Precio 
de Venta es la 
directamente 
involucrada en el 
calculo. 


Figura 7.4- Esquema de Aplicacion del Filter Context 


Podemos apreciar del esquema anterior como cada coordenada del 
filter context se aplica como filtro a su respectiva tabla. 
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Sabemos que La medida en el esquema anterior es: 


NOTA: jlmportante! 

La propagation de filtros 
unicamente ocurre de las 
tablas de busqueda a la 
tabla base, es decir, la 
propagacion no sucede 
de la tabla base a las de 
busqueda. 

Los filtros en la tabla base 
solamente la afectan a ella 
y nada mas. Esto es 
extremadamente 
importante. /No lo olvides! 


TABLA_Pedidos[Colombia Suma Precio de Venta]:= 
CALCUALTE([Suma of Precio de Venta];Pedidos[Pais]="Colombia") 


En cuyo caso por lo que hemos venido hablando sabemos que la 
formula a ejecutarse es: 

[Suma of Precio de Venta] 

Ouien al mismo tiempo es: 


SUM([Precio de Venta]) 


Pausemos un Momento 



Insistimos nuevamente en resaltar como estan construidas y 
organizadas las medidas, para este caso la medida: [Colombia Suma 
Precio de Venta], Tambien, recordemos que cada valor de las celdas 
se calcula independientemente siguiendo el diagrama de fluj'o. 
Repetimos para no tomar rlesgo de ambiguedades, pues es de vital 
importancia de ahora en adelante. 


Lo que queremos aclarar es que en la columna Precio de Venta de la 
tabla pedidos es donde se hara la suma segun el contexto, sin 
embargo, si detallamos el esquema anterior podemos ver que no 
sabemos aun de que manera afectan los filtros de las otras tablas 
(Descuentos y SKU Productos) para el calculo en dicha columna en 
La tabla Pedidos. 

\iw," 


m'WsWWs'Ww W ® WWW 






El ADN DE Power Pivot 


Resulta que los filtros (Coordenadas) de las tablas de busqueda 
(aquellas que contienen el campo con elementos unicos) propagan 
sus filtros a la tabla matriz. Tomando la figura siguiente fijemonos 
en las formas rojas: 



Propagar 


Coordenadas del Filter Context 

-• Descuentos[Descuento]=0.25 

Pedidos [Categoria de Descuentos]=”Devo/uc/dn” 

Pedidos [Pais]=”Co/omb/a” 9 _ 

‘SKU Productos’[Producto(s)]= ’’The Dark Knight” 




Descuento (%) 




Categ 


£o^25^Balck Fradayi 


Tabla Descuentos | Tabla de Busqueda 




■ 

—# 

l r 


13. 


Tabla SKU Product 


] Produc 

to(s) 

kd 

[The D; 

rk Knight _j 


>(s) | Tabla de Busqueda 


Tipo de Cornpra 


Devolution 

Tabla Pedidos | Tabla Matriz 


BQ2 j Balck Fraday 

Figura 7.5- Esquema Propagacion de Filtros 


-45.-435. Colombia Mede 


jAsi escomose propagan los filtros!, si aplica. Ya que si no hay tablas 
relacionadas este paso no existiria, todo estaria en la tabla matriz. 


jToma Nota! 



En el ejemplo solamente quedo una fila despues de la aplicacion de 
coordenadas y propagacion, aunque, pueden quedar mas dependiendo 
de la situacion. Por otra parte, en el ejemplo anterior los filtros a propagar 
siempre coincidieron con un unico elemento, pero eso no es asf siempre, 
ya que pueden quedar mas, en este caso se propagan todos los elementos 
y se hace el filtro para cada uno como una union. 
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NOTA 

Ffjate como la familia de 
funciones de "alteracion" 
(Calculate, All y Filter) se 
ejecutan en el query 
context, es decir en la 
segunda etapa, mientras 
que las demas funciones 
de agregacion se ejecutan 
en la quinta etapa, pues 
son estas las que resumen 
un conjunto de datos en 
un unico valor para poder 
ser presentado en la celda 
del reporte. 


NOTA 

Tomemos este momento 
para decir que: La 
expresion DAX puede 
tener multiples filter 
context donde cada uno 
es diferente y se aplica a 
partes especfficas de la 
expresion, hasta el 
momento no hemos visto 
un escenario donde se de 
esta situacion, sin 
embargo, es primordial 
mencionarlo aquf y 
tenerlo bien claro para el 
proximo capitulo. 


Etapa 5: EvaLuar Expresion DAX 

En esta etapa, una vez se tiene todo filtrado y propagado en Las 
tabLas, se procede a ejecutar Las funciones de agregacion en la 
expresion, para el ejempLo correspondiente al valor $45 de la tabla 
dinamica de la figura 7.3, atane a la suma de los elementos en la 
columna Precio de Venta. 


Tipo de Compra 

E3 

s..< 

m 

Gategoria de Desc... 

E 

Precio de Venta E 

5 

□ 

|| Pais \M 

Devolution 

B02 

Balck Fraday 

45.435 




Colombia | 


Figura 7.6- Filas Restantes Despues de Aplicar Coordenadas y Propagar 


Para el ejemplo que hemos seguido en los ultimos parrafos solo 
queda una fila pues el valor de la suma sera el mismo que el 
presentado en la tabla, a pesar de ello, si hubieran quedado mas se 
ejecutaria en todas ellas, sumando cada elemento de las filas en el 
contexto. 

Por ejemplo, si creamos la siguiente tabla dinamica con la medida 
Suma of Precio de Venta en el area de valores y analizamos la celda 
sehalada en la imagen siguiente: 


Pais Ecuador t t 



Figura 7. 7 - Analizar la Celda Senalada 































El ADN DE Power Pivot 


m 


Vamos a encontrar que el filter context esta compuesto por las filas 


en la imagen a continuation: 


Tipo de Compra 


Normal 

Devolution 


BO 2 
BO 2 



c... -IS 

Pretio de Venta T 

!S 

... 

Pai5 


Baltk Fraday | 45.435 1. . 



Etuador 


Baltk Fraday 136.305 ... 



Etuador 


3 


Figura 7.8- Filter Context del Valor 181.74 del Reporte de la Figura 7.7 


En este escenario 
quedan dos filas, y 
por lo tanto la 
medida se aplica a 
estos dos elementos. 


Etapa 6: Retornar Resultado para Analisis Dinamico 

Nada raro aqui, solo toma el calculo y lo lleva a la posicion en el 
reporte de tabla dinamica. 


Tipo de Compra 


Normal 

Devolution 


Categoria de Dest... 


B02 Baltk Fraday 

B02 Baltk Fraday 



=SUM(TABLA_Pedidos[Precio de Venta] 
(D =SUM(45.43.5;136.305) 

(? =181.74 - 


Pais 


Ecuador 


Etiquetas de fila Q Sum of Precio de Venta 


0 

1453.92 

0.15 

102.986 

0.2 

823.888 

0.25 

181.74 

0.35 

236.262 

Total general 

2798.796 


Producto(s) 

III 

Sears & Ze man sky 1 5 l 

Iniversity P... 

a 

V 

The Dark Knight 

The Dark Knight Rises 

99 Must-Have Mozart Masterpi... 


En este escenario 
quedan dos filas y por 
lo tanto la medida se 
aplica a estos dos 
elementos. 


Figura 7.9- Esquema Etapa 6 
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Coordenadas Vs 
Filtros Vs 
Contextos 


Qarifiquemos cual es la diferencia entre coordenadas, filtros y 
contextos. Para ponerlo bien facil: Las coordenadas son los filtros a 
aplicar en las distintas tablas, mientras que el contexto es el 
conjunto de filas restantes despues de haber aplicado los filtros y 
propagado. Haciendo un Sumario: 


■ Coordenada: Filtro a aplicar ("Filtro Virtual") 

■ Filtro: Filtro ya aplicado en la tab la ("Filtro Real") 

■ Contexto: Conjunto de filas restantes despues de aplicar 
filtros. 

Esquematizacion de Contexto 

El proceso para determinar los valores en el cuerpo de una tabla 
dinamica, su secuencia, logica, y todo lo relacionado con contextos, 
es tan importante para ser unos verdaderos maestros en el lenguaje 
DAX y construccion de modelo de datos, que es casi que obligatorio 
contar con representaciones visuales que nos ayuden a entender e 
interiorizarlo, ya sabes, volverlo tan intuitivo y natural como la tabla 
del dos. 


Pausemos un Momento 



Queremos detenernos un momento aqui Es importante, que este 
capttulo lo entiendas a la perfeccion, es mas, incluso una vez hayas 
avanzado el resto de capttulos, es vital repasar e ir afianzados cada 
vez mas con esto, pues es un tema con muchos detalles y de gran 
trascendencia. Generalmente requiere de varias lecturas. 







El ADN DE Power Pivot 




Medida: Colombia Suma of Precio de Venta \ Valor: $45 \ Configuration: Tabla Dinamica Figura 73 

(I): Detector Query Context 



(3): Construir Filter Context 

Familia Calculate: Modifica ylo Agrega 


Filter Context 


Pedido5[De5cuento]=0.25 
Ped Idas[Categona de D e s c uenro]='Devofuddn 
Pe d i d o 5 [Pai: 5 ]—"Coforrt biar” 

S KU Productos’[Producto(s)] ='The Dork Knight 


(4): Aplicar y Propagar 


II Catego rfa de Desci 


0.25 jB lack F rad ay 


3 


B 0 2 [The Dark Knj'gh ! 


I Preciode Vneta 


| Pais Qj| 


-► Devolution 


BQ2 Black Fraday 


45.435 Poloi 


J 


(6): Retornar Valor 


enta Colombia Suma Precio de Venta 


21.16 

S.856 
>305 f 


$242 
$ 194 


$45| 


(5): Ejecutar Expresion 

© [Suma of Precio de Venta] 

SUM(TABLA_Pedidos[Precio de Venta]) 
© SUM(45.435) 

© $45 


Entender Flujo de Calculo 


Nosotros recomendamos hacer esquemas similares cuando se esta 
en el aprendizaje 0 solucionando problemas complejos en DAX, ya 
que como veremos mas adelante hay situaciones mas complicadas 
que requieren de entender bien el flujo calculo. Otro ejemplo: 
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Medida: Suma ofPrecio de Venta \ Valor: 136.305 \ Configuration: Tabla Dinamica Figura 7.1 
(I): Detector Query Context 



Query Context 


Pedido5[De5cuento]=0.25 


Pedidos[Oategoria de Desc uento]="DevoJuti6n" 



Pe d i d o 5 [Pai s] ="Ecu odor" 



S'KU Prod uctos 1 [Prod ucto(s)]='T.he Dork Knight" 




(2): lExisten Constrains Context?: NO 


(3): Construir Filter Context (4) . Apljcar y Propagar 

Como no hay Constrains el Filter Context es el 
mismo Query Context 


Fitter Context 


Pedidos[Descuen to] =0.25 
Pedidos[Categoria de Desc uento] ="Devo/uti6n” 
Pe d i d o 5 [Pais] ="Ecu a dor " 

S’KU Productos{Producto(s)]= J The Dork Knight" 




Desucento(?4] Q ' Categonia de DescI 


0.25 1 Black Fra day 




B 0 2 ffie Dark Knigh ! 

a '. 


Tipode Compra 


[ Ctagoria de Q Preciode Vneta Pais 


^►Devolution 


B02 Black Fraday 


136.305 fc 



(6): Retornar Valor 


fila Q Sum of Precio de Venta Colombi; 


121.16 

193.856 

136.305 


(5): Ejecutar Expresion 

© [Suma of Precio de Venta] 

SUM(TABLA_Pedidos[Precio de Venta]) 
© SUM(136.305) 

© 136.305 


Las esquematizaciones las utilizaremos en momentos claves de 
ahora en adelante para resumir el diagrama de flujo y ver como se 
estan determinando los valores en el cuerpo de la tabla dinamica 
detras de camara, hasta aqui entendemos como se lleva acabo y 
como los constrains juegan un papel crucial; estos son alteraciones 
que pueden ser de tres tipos: Modificacion, Agregacion o Remocion. 
Vimos como modificar o agregar si es el caso las coordenadas la 
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Tactica Nemotecnica 

Tener impreso en nuestra memoria el diagrama de flujo del 
proceso para el calculo de medidas es algo que hemos enfatizado 
fuertemente en estas ultimas paginas, y no es para menos, pues es 
el secreto para entender aplicaciones de alta complejidad y ser 
unos gurus en el lenguaje DAX. Para facilitar la memorizacion el 
diagrama de flujo la siguiente tactica nemotecnia puede ser de 
utilidad; si tomamos las iniciales de cada paso en el proceso de 
diagrama de flujo se forma la siguiente palabra: 


DECAER 


Con esto ya podemos tomar cada inicial, organizarlo una debajo de 
la otro y describir en que consiste cada etapa 


I )etectar coordenadas del Query Context 
Existen Constrains? 

Construir Filter Context 
Aplicar coordenadas (Propagar si aplica) 
jecutar expresion 
,etornar valor 


Recordar la palabra DECAER tambien es facil, si la relacionamos con 
la propagacion, pues se propagan de forma decreciente, de arriba 
abajo, DECAEN segun nuestra organizacion de tablas. 
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Etapas para Columnas Calculadas 

Ya hemos discutido como se determina una columna calculada en 
el capitulo anterior, sin embargo, dejemos su diagrama de flujo aqui 
y repasemos rapidamente cada etapa. 


NOTA 

Ya hemos abordado los 
fundamentos del proceso 
para determinar las 
columnas calculadas, el 
diagrama de flujo 
simplemente estructura lo 
que ya hemos tratado. 

Mas adelante veremos 
aplicaciones con Row 
Context mas complejas, 
pero interesantes y de 
gran utilidad. 
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Etapa 1: ^Es una Funcion de Agregacion? 

La etapa uno identifica si la funcion es de agregacion si es asi sigue 
directamente a la etapa siguiente, de lo contrario salta a la etapa 3. 

Etapa 2: Aplicar a la Columna Completa 

Como es una funcion de agregacion entonces esta se aplica a la 
columna completa (Ignora el Row Context) a la que este haciendo 
referencia o a las que este haciendo referencia (unicamente en las 
funciones de agregacion ya que la expresion DAX puede contener de 
otro tipo, todo depende de la anidacion y el orden de resolucion de 
calculos). 


Etapa 3: Aplicar fila a fila (Row Context) 

Si la funcion no es de agregacion, entonces se ejecuta la funcion 

fila por fila. Este recorrido fila a fila es el Row Context. El Row Row Context 

Context no es otra cosa que la fila actual, el cual lo define del DAX 
Engine de manera automatica. 


Etapa 4: Retornar Resultado 

Retorna resultado: Aqui simplemente se coloca el valor en la celda 
correspondiente. 


Pausemos un Momento 



Hay escenarios mas complejos y versatiles con el Row Context, como 
Multiples Row Context (Anidacion) o Transition Context, pero por el 
momento relajemonos y disfrutemos de entender el proceso de 
ejecucion de las columnas calculadas facilmente. 
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Take Aways 

Conclusiones:" Para LLevar" 


De los procesos para hallar Los dos tipos de calculos personaLizados 
y los contextos podemos sacar una serie de conclusiones para tener 
siempre en cuenta; para llevar. 


Take Away Numero 1: Encapsulacion 

Las medidas siempre deben estar encerradas (Encapsuladas), por 
una funcion de agregacion, en otras palabras, no podemos crear 
una medida que solamente utilice operaciones entre columnas, 
pues ello conducira a un error inevitable. iPuedes inferir por que? 


Para dejar el take Away numero uno claro, veamos La tabla dinamica 
siguiente: 



CM M55.6675 

CBOI 123726.2175 

CCOI 20526.0975 

CC02 _ 6793.56 

Total general I 57836.345 

Figura 7.10 - Tabla Dinamica para el Take Away Numero 1 












El ADN DE Power Pivot 


Supongamos que queremos anadir la siguiente medida. 


TABLA_Pedidos[Costo Variable]:= 
TABLA_Pedidos[Costo de Envio] 


Asumamos que Power Pivot nos deja crear la medida sin ningun 
inconveniente; posteriormente la llevamos al area de valores para 
que quede en paralelo con la medida Sum of Predo de Venta en el 
reporte, el reporte deberia lucir algo del siguiente estilo: 


Gategoria de Descuento Balck Fraday | t t] 


Etiquetas de fila 

EJS 

urn of Precio de Venta Costo Variable 

CIO 


1307.01 

Cl 1 


1760.94 

Cl 2 


962.34 

CI3 


1304.5125 

CI4 


1455.6675 

CBOI 


123726.2175 

CCOI 


20526.0975 

CC02 


6793.56 


Total general I 57836.345 


Figura 7.11- Reporte al que deseamos llegar 


Visualicemos como se calcularia la celda resaltada en la figura 
anterior. Debemos detectar el query context que seria el mismo 
filter context ya que en la medida Costo Variable no hay funciones 
constrains, por lo que tendriamos las siguientes coordenadas: 


■ Pedidos[SKU]= "CIO" 

■ Descuentos[Categoria de Descuentos ]=''Blacl< Fraday" 




NOTA 

La tabla dinamica de la 
figura se creo como 
ilustracion ficticia ya que 
algo de del estilo de la 
medida Costo Variable no 
esta permitido (No se 
puede crear). Por lo tanto, 
toma la imagen de la 
figura en lugar de tratar de 
ere aria en la hoja de 
calculo de Excel. 








Capitulo 7 / Back-Office, Contextos: DAX Engine Detras de Camaras 



Aplicando las coordenadas a la tabla pedidos y propagando de la 
tabla descuentos a la tabla pedidos obtendriamos el siguiente filter 
context. 



Categoria de Desc... *0 E2 

Precio de Venta E 

Unidades E 

Costo del Producto E 

Costo de Envio v 

CIO 

Balck Fraday 

103.185 

3 

5.73 

3.73 

CIO 

Balck Fraday 

68.79 

2 

6.99 

5.99 

CIO 

Balck Fraday 

34.395 

1 

10 

5 

CIO 

Balck Fraday 

34.395 

1 

6 

7 

CIO 

Balck Fraday 

68.79 

2 

7.9 

3.9 

CIO 

Balck Fraday 

34.395 

1 

7.9 

4.9 

CIO 

Balck Fraday 

103.185 

3 

6.14 

3.14 

CIO 

Balck Fraday 

68.79 

2 

7.45 

3.45 

CIO 

Balck Fraday 

103.185 

3 

8.22 

3.22 

CIO 

Balck Fraday 

103.185 

3 

8.58 

3.58 

CIO 

Balck Fraday 

103.185 

3 

6.22 

5.22 

CIO 

Balck Fraday 

103.185 

3 

8.55 

4.55 

CIO 

Balck Fraday 

34.395 

1 

8.45 

4.45 

CIO 

Balck Fraday 

68.79 

2 

7.45 

5.45 

CIO 

Balck Fraday 

34.395 

1 

9.61 

5.61 

CIO 

Balck Fraday 

68.79 

2 

8.99 

3.99 

CIO 

Balck Fraday 

68.79 

2 

9.99 

4.99 

CIO 

Balck Fraday 

103.185 

3 

6.99 

5.99 


Figura 7.12 - Filter Context paro el Reporte de lo Figuro 7.11 


Ahora en la etapa de calculo Power pivot se pregunta que hacer, 
pues tiene que mostrar lo que esta en la columna envio en la celda 
de la tabla dinamica, es decir, como va resumir ese conjunto de 
elementos para "empaquetarlos" y presentarlos en la celda 
correspondiente, vease el esquema enseguida: 





CIO 

Balck Fraday 

103.185 

3 

5. 


3.73 ' 

5.99 

5 

7 

CIO 

Balck Fraday 

68.79 

2 

6.' 

CIO 

Balck Fraday 

34.395 

1 


CIO 

Balck Fraday 

34.395 

1 


CIO 

Balck Fraday 

68.79 

2 



3.9 

CIO 

Balck Fraday 

34.395 

1 



4.9 

CIO 

Balck Fraday 

103.185 

3 

6. 


3.14 

CIO 

Balck Fraday 

68.79 

2 

7/ 


3.45 

CIO 

Balck Fraday 

103.185 

3 

8.: 


3.22 

CIO 

Balck Fraday 

103.185 

3 

8.: 


3.58 

CIO 

Balck Fraday 

103.185 

3 

6.: 


5.22 

CIO 

Balck Fraday 

103.185 

3 

8.! 


4.55 

CIO 

Balck Fraday 

34.395 

1 

8, 


4.45 

CIO 

Balck Fraday 

68.79 

2 

7/ 


5.45 

CIO 

Balck Fraday 

34.395 

1 

9. 


5.61 

CIO 

Balck Fraday 

68.79 

2 

8.' 


3.99 

CIO 

Balck Fraday 

68.79 

2 

9.' 


4.99 

CIO 

Balck Fraday 

103.185 

3 



5.99 a 


Categoria de Descuento Balck Fraday 


0 


iComo vas a hacer la 
tabla dinamica para 
empaquetar toda la 
columna y resumirla 
para presentarla en una 
celda? 


Etiquetas uc H!c. 


CIO 

CM 

CI2 

CI3 

CI4 

CBOI 

CCOI 

CC02 


R3 Sum of Precio de Venta Costo Variable 


1760.94 

962.34 

1304.5125 

1455.6675 

123726.2175 

20526.0975 

6793.56 


Total general 


157836.345 


Figura 7.13 - Esquema empaquetar columna para presentar en la celda del reporte 
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Esta es la razon por la cualtoda medida debe estar encapsulada en 
una funcion de agregacion, para poder resumir un conjunto de 
valores y presentarlos en la celda correspondiente en el cuerpo de 
la tabla dinamica, de hecho, si tratamos de anadir la medida Costo 
Variable a Power Pivot no muestra el siguiente mensaje de error. 


Power Pivot para Excel 


? X 


© Nose pudo agregar el campo "Costo Variable" a la tabla dinamica porquela formula no esvalida. 


Aceptar 


Figura 7. 14 - Error de Power Pivot al Trotor de Ahodir Medidas no Encapsuladas 


El escenario de la situacion anterior es facil de evitar y sencillo de 
identificar, sin embargo, hay algunas circunstancias en las que la 
encapsulacion es algo mas tramposa, supongamos por ejemplo 
que el valor del producto CIO en la tabla dinamica de la figura 7.10 
lo queremos multiplicar por 2 (Los demas no hacerlas nada). La 
medida que nos llega a la mente instantaneamente es esta: 


TABLA_Pedidos[ClO Doble Suma Precio de Venta]:= 
IF( TABLA_Pedidos[SKU]="ClO"; 

[Suma of Precio de Venta]*2; 

[Suma of Precio de Venta] 

) 




Como ya habras deducido, la medida conduce a un error iPor que? 
- porque no hay una encapsulacion adecuada, si analizamos el 
primer argumento de la funcion IF estaria pasando lo siguiente: 
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BO I 
BO 2 
BO 3 


Para la situacion planteada 
solamente necesitamos este 
elemento. 



Cl I 

Cl 2 

Cl 3 

04 

CBOI 

CCOI 

CC02 

LOI 

L02 

L03 

L04 


LOS 

L06 

L07 


"CIO 


a 


Power Pivot no sabe como tratar esta situacion pues no sabe como 
interpretar TABLA_Pedidos[SKU], ya que no esta encapsulada para 
poder resumirla, para entenderlo de forma sencilLa, identifica que 
esta parte del argumento no esta encapsulado, retornando un error. 
iLa solution?, bien, si analizamos las coordenadas de la posicion 
donde queremos que aparezca el valor, obtendriamos como 
coordenadas: (Esto es de acuerdo al reporte de lafigura 7.10) 

■ TABLA_Pedidos[SKU]= "CIO" 

■ Descuentos[Categoria de Descuentos]="B/oc/< Fraday" 


Como podemos ver en las coordenadas, solamente los CIO estan 
filtrando la tabla, si contaramos con una funcion que nos trajera los 


elementos unicos de una columna obtendriamos una comparacion 
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Bien, te presentamos La funcion VALUESQ. 


VALUES(<Tabla o Columna>) 

La funcion VALUES retorna todos Los vaLores distintos de una 
coLumna especificada en su argumento o tabLa, dicho de otra 
manera, remueve Los elementos duplicados y devuelve Los 
eLementos unicos. Por Lo que La formuLa correcta para nuestra 
situacion seria: 


TABLA_Pedidos[ClO Doble Suma Precio de Venta]:= 
I F(VALUES(TABLA_Pedidos[SKU])= "CIO"; 

[Suma of Precio de Venta]*2; 

[Suma of Precio de Venta] 

) 


NOTA 

La funcion DISTINCT es 
practicamente igual a 
VALUES, pero no 
identicas, en la gran 
mayoria de los casos se 
puede utilizar cualquiera 
de las dos sin ningun 
inconveniente, aunque, 
hay escenarios donde una 
trabaja de manera 
correcta y la otra no, mas 
adelante veremos sus 
diferencias, por el 
momenta utiliza la funcion 
VALUES. 


No obstante, La expresion DAX anterior arroja un error debido a que 
puede haber mas de un vaLor en La coLumna, para soLucionarLo 
extendamos La expresion asi: 


TABLA_Pedidos[ClO DobLe Suma Precio de Venta]:= 
IF(COUNTROWS(VALUES(TABLA_Pedidos[SKU]))=l; 
IF(VALUES(TABLA_Pedidos[SKU])="ClO"; 
[Suma of Precio de Venta]*2; 


[Suma of Precio de Venta] 

); 


[Suma of Precio de Venta] 
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jToma Nota! 



No confundas la funcion VALUE con VALUES, aparte de diferenciarse en 
la S al final, son funciones bien diferentes. VALUE es una funcion de 
conversion que transforma un valor de tlpo texto en numero; mientras 
que la funcion VALUES retorna la lista de elementos unicos. 


Take Away Numero 2: Omision 

Hemos recalcado esto tambien bastante, y lo escribimos aqui 
nuevamente para no excluirlo por su importancia: Las funciones de 
agregacion en Las coLumnas calculadas ignoran u omiten eL Row 
Contexty se aplican a La coLumna completa a lacualseesta haciendo 
referencia, o a Las que se esten haciendo referencia. 


Take Away Numero 3: Contextos 


NOTA 

Hay situaciones en donde 
puede haber excepciones 
en los contextos, a parte 
de lo mencionado en take 
Away numero 2, pero por 
ahora, tomemos la teorfa 
como se ha descrito y en 
su debido momenta 
veremos las alternativas. 


Las coLumnas calcuLadas se apLican en eL row context, mientras que 
Las medidas se aplican el filter context Los Contextos: Query 
Context y Constrains son en realidad pasos intermedios que 
permiten construir el contexto de datos para evaluar las funciones 
de agregacion, es decir el filter context, el cual si se aplica en La 
tabla y por lo tanto si construye un contexto. 

Por otra parte, una expresion DAX dependiendo de su complejidad 
puede tener uno o mas filter context que se aplican a diferentes 
miembros de la formula, estos escenarios son bastante frecuentes 
y los encontraremos en toda clase de situaciones, veremos esto 
mas adelante. 

_ _ __ _ (fti 
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Take Away Numero 4: Escalar o Tabla 

Como se ha podido inferir de las paginas anteriores, las funciones 
DAX pueden devolver bien sea un valor unico al que llamaremos 
escalar o un conjunto de valores, en este ultimo caso decimos que 
la funcion devuelve una tabla; tome por ejemplo el caso de la 
funcion VALUES, esta retorna una tabla de una columna con los 
valores unicos. 



Pausemos un Momento 

Tomate el tlempo necesario para comprender bien la teor'ia de este 
capttulo, leelo varias veces si es necesario, es mejor avanzar con la 
mayor comprension posible a los siguientes temas, debido a que todo 
esta construido en base a estos pilares teoricos, de ahora en adelante 
asumiremos ya se entiendes por lo menos en un 80 %. 


El Siguiente Paso 

Despues de conocer una parte bien importante del proceso detras 
de camaras que existe para las medidas y columnas calculadas, te 
presentaremos la joya de la corona en el lenguaje DAX, y otras 
poderosas expresiones que te daran una vision amplia del poder 
de Power Pivot y el Lenguaje DAX. 









La Presente Pagina se ha dejado en Blanco de forma deliberada. 
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Capftulo 8 / El Artede las Medidas 



Reportes Cuanticos 

Funcion CALCULATE 


NOTA 

El presente capftulo aparte 
de ser el mas largo de 
todo el libro, es el mas 
complejo e importante, los 
ejemplos y tematicas aquf 
presentados 

proporcionan la caja de 
herramientas para 

encaminarnos hacia la 
experticia Power Pivot yen 
especffico el lenguaje 
DAX. No trates de leer 
este capftulo rapidamente, 
ni siquiera considere 
estudiarlo en un solo dfa, 
pues requiere de analisis, 
practica y varias lecturas 
para comprender y 
dominar los diferentes 
temas del capftulo; tomate 
tu tiempo para absorber y 
comprender de la mejor 
manera: cada ejemplo, 
cada nueva funcion y cada 
nuevo concepto. 

"Energia y Persistence 
Conquista Todas las 
Cosas." Benjamin Franklin 


La funcion CALCULATE de la cual hemos visto sus fundamentos en 
el capitulo previo, es considerada la joya de la corona en el lenguaje 
DAXy, no es para menos, puesto que la cantidad de escenarios en 
la cual es vital son innumerables, ademas, con lo que hemos 
explorado sobre ella hasta el momento hemos visto que tiene un 
comportamiento "cuantico". <_Comportamiento Cuantico? - \De que 
estas hablando! - Se te estara pasando por la cabeza - 

En fisica, la mecanica cuantica ensena que el mundo (Microscopico) 
describe un comportamiento frenetico donde la intuicion no es 
valida y donde lo imposible e irracional sucede; por ejemplo: El 
Postulado Dualidad Onda/Particula ilustra que las particulas se 
describen y comportan como dos cosas distintas al mismo tiempo, 
como onda y particula. Imaginemelo de esta manera, hemos sabido 
que una roca en el oceano es eso, una roca en el oceano; mientras 
que una ola es algo independiente, sin embargo, la mecanica 
cuantica nos dice que una roca en el oceano es a su vez una ola. 
jEsto es extranol, lo se, pero lo que queremos sacar de la mecanica 
cuantica es que nos dice que algo puede tener dos estados al 
mismo tiempo, como, por ejemplo: el gato de Schrodinger. 

No te vamos a aburrir hablando de fisica, pero si queremos decirte 
que las tablas dinamicas tienen un comportamiento cuantico 
gracias a la funcion CALCULATE. jNo lo has notado mientras 
estudiabamos la etapa dos en medidas en el capitulo anterior? 
Permitenos exponerlo nuevamente sin mucho rodeo. 


NOTA 

El presente capitulo aparte 
de ser el mas largo de 
todo el libro, es el mas 
complejo e importante, los 
ejemplos y tematicas aquf 
presentados 

proporcionan la caja de 
herramientas para 

encaminarnos hacia la 
experticia Power Pivot yen 
especffico el lenguaje 
DAX. No trates de leer 
este capitulo rapidamente, 
ni siquiera considere 
estudiarlo en un solo dfa, 
pues requiere de analisis, 
practica y varias lecturas 
para comprender y 
dominar los diferentes 
temas del capitulo; tomate 
tu tiempo para absorber y 
comprender de la mejor 
manera: cada ejemplo, 
cada nueva funcion y cada 
nuevo concepto. 

"Energia y Persistence 
Conquista Todas las 
Cosas." Benjamin Franklin 
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Observe el siguiente reporte de table dinamica: 


Pafs 




Argentina 

Brasil 

Chile 

Colombia 

Ecuador 

a 

Paraguay 

Peru 

Uruguay 

Venezuela 


V 


Etiquetas de fila Q 5 

urn of Precio de Venta Colombia Suma 

Precio de Venta 

CIO 

$19,337.32 

$1,910.07 

Cl 1 

$28,657.67 

$3,042.51 

Cl 2 

$13,765.19 

$1,515.87 

Cl 3 

$ 1 7,284.29 

$1,978.01 

CM 

$ 18,755.34 

$1,622.03 

CBOI 

$1,885,900.62 

$212,427.20 

CCQI 

$313,914.03 

$35,326.43 

CC02 

$109,568.03 

$1 1,004.63 


Total general $2,407,232.47 $268,826.75 


Figura 8.1- Reporte paro Analizar Comportomiento Cucmtico 


La tabla dinamica esta simultaneamente filtrada y no filtrada, dos 
estados a la vez. La primera medida (Sumo Of Precio de Venta) 
realiza la suma segun los paises que se seleccionen en el Slicer, en 
el caso de la tabla dinamica en la figura anterior: todos los paises 
porque no se ha escogido ningun elemento en el Slicer, por otra 
parte, la segunda medida (Colombia Suma Precio de Venta) tiene un 
filtro aplicado en el pais que corresponde al elemento Colombia. 
jEs mas notorio ahora que lo vemos de esa forma!: Los reportes de 
tablas dinamicas con CALCULATE tienen un comportamiento 
cuantico, es decir, podemos hacer que el reporte este filtrado y no 
filtrado al mismo tiempo. 


Ahora hagamos el siguiente ejercicio: Pasemos el campo SKU al 
area de filtros, anadamos el campo Pais al area de filas y 


removemos todos los filtros que esten aplicados en el. 

mmffkrnmmm. 





fl 






wiimww 


m 


It 


7/ 

if 





NOTA 

En la tabla dinamica se 
agrega el campo SKU de 
la tabla Pedidos y se filtran 
todos los elementos por la 
letra C, ademas, se 
agregaron las medidas: 
Sum of Precio de Venta y, 
Colombia Suma Precio de 
Venta al area de valores. 

Por otra parte, se creo un 
Slicer con el campo Pais 
(Sin Ningun elemento 
Filtrado). 
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Recuerda que 
aqui hemos 
aplicado un filtro 
para tener en 
cuenta 

solamente los 
elementos que 
empiezan por la 
letra C. 



SKU 


(Varies elementos) £xj 


Etiquetas de fila g’ 

Sum of Precio de Venta t 

Colombia Suma Precio de Venta 

Argentina 

$278,239.91 

$268,826.75 

Brasil 

$262,963.70 

$268,826.75 

Chile 

$251,088.36 

$268,826.75 

Colombia 

$268,826.75 

$268,826.75 

Ecuador 

$272,393.99 

$268,826.75 

Paraguay 

$272,55-4.00 

$268,826.75 

Peru 

$267,948.03 

$268,826.75 

Uruguay 

$252,836.75 

$268,826.75 

Venezuela 

$280,380.99 

$268,826.75 

Total general 

$2,407,232.47 

$268,826.75 


Figura 8.2- Reordenocion de Compos en el Reporte 


^Puedes decirnos por que todos los valores que corresponden a la 
medida: Colombia Suma Precio de Venta son iguales? Algunas 
opciones para resumir un poco: 

a) Hay un Bug para hallar el valor, debido a que el filtro esta 
aplicado en Colombia solamente deberfa aparecer en dicho 
elemento, mientras que en los demas un cero. 

b) Las coordenadas del constrains sobrescribe las coordenadas 
del query context antes de determinarse los calculos, por lo 
que para cada celda en la tabla dinamica siempre tendra 
como filtro: Colombia, por consiguiente, valores iguales. 


Esperamos que hayas seleccionado la opcion b, puesto que como 
vimos en el capftulo anterior en la etapa dos, que es previa la 
ejecucion del calculo, dice que predomina la coordenada del 
constrain, sobrescribiendo todas los demas. 

imp® mm 
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Funcion CALCULATE 

Aterricemos lo que hemos visto en los diferentes momentos sobre 
la funcion CACULATE para asi ir plasmando todo en un solo lugar. 

La funcion CALCULATE del lenguaje DAX evalua una expresion, 
como, por ejemplo: SUMA, CUENTA, MEDIANA, etc. Anadiendo, 
removiendo o modificando coordenadas del query context 


=CALCULATE(<expresion> [; filtrol] [; filtro2];...) 


La funcion CALCULATE tiene un numero indefinido de argumentos 
o parametros: 



Argumentos o Parametros de la funcion CALCUALTE 

Argumento 

Description 

Expresion 

La Expresion DAX a evaluar, por ejemplo: 

SUM(Precio de Venta) 6 MEDIAN(Pedidos[Costo Total] 

6 DISTINCTCOUNT(Fecha de Envio) 

[Filtro 1] 

(Optional) Una Expresion Booleana o tabla para 
definir los filtros, ejemplos: Pedidos[Pai's]="Peru" 

[Filtro 2];... 

(Optional) Igual que el argumento 1 


Aprovechemos este espacio y veamos la funcion CACULATE desde 
otro angulo, desde Excel y las funciones de resumen en la 
funcionalidad de tablas dinamicas. 




Definicion 


Sintaxis 


Argumentos 


Otra 

Perspectiva 
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NOTA 


La familia ".SICONJUNTO" 
es bien reducida, ya que 
solo cuenta con: SUMA, 
PROMEDIO y CUENTA. 
Alternativas Con MIN, 
DESVEST.M, etc. No 
existen. 


Lo Anterior no quiere 
decir que no se pueden 
crear, aunque, requieren 
de manejo matricial, en el 
siguiente video se explica 
como extender la familia 
de las funciones 
condicionales: 



Si Lo analizamos y tratamos de encontrar una funcion similar en 
Excel no la hallaremos, sin embargo, curioseando un poquito mas 
nos encontramos que su comportamiento es como el de las 
funciones: SUMAR.SI, SUMAR.SI.CONJUNTO, CONTAR.SI, CONTAR.SI, 
CONTAR.SI.CON JUNTO, etc. CALCULATE es como todas ellas y 
mucho mas, dado que en el primer argumento podemos poner 
cualquier expresion que deseemos, un ejemplo: 

CALCULATE(MAX(TABLA_Pedidos[Unidades]); 

TABLA_Pedidos[Pais]= "Chile') 

Situacion que en Excel no es tan evidente, puesto que no contamos 
con una funcion MAX.SI o MAX.SI.CONJUNTO y mucho menos con 
sus equivalentes en desviacion estandar. En la funcionalidad de 
tablas dinamicas es como si tuvieramos todas ellas y mas en la lista 
de funciones de resumen. 


Extension Funciones 

Condicionales 

El 9 febrero del 2016 
(Mientras se escribfa este 
libro) Microsoft Lanzo una 
actualizacion para Office 
365 que cuenta con: 
MAX.SI.CONJUNTO, 
MIN.SI.CONJUNTO, 
SI.CONJUNTO, 
UNIRCADENAS, 

CAMBIAR, CONCAT. 
Eventualmente 
apareceran en todas las 
ediciones, aunque puede 
tardar, incluso anos. 



Configuration de campo de valor 

Nombre del origen:: Minutos 
Nombre personalizado; 


X 


Suma de Minutos 


Resumir valores por Mostrar valores como 

Resumir campo de valor por 

Elija el tipo de calculo que desea usar para resumir 
datos del campo seleccionado 


Recuento 

Promedio 

Max. 

Min, 

Producto 
Contar numeros 
Desvest 
Desvestp 
Var 
Varp 


Sumar.SI.Conjunto,... 


Formato de numero 





Aceptar 


Cancelar 



CALCULATE es como 
si tuvieramos en las 
funciones de 
resumen una gran 
lista de la familia 
(.SI.CONJUNTO) y 
mas, dada la 
flexibilidad del 
argumento 
expresion, 
adicionalmente 
brinda una sintaxis 
mas amigable y 
limpia. 




f 


It 



Figura 8.3- 


Otro Angulo de Vision con CALCUALTE 
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Vista Multiple 
Situation 1 


Podemos presenter en un reporte el resumen de diversos paises y 
generar en una sola vista. 


[Peru]:=CALCU LATE( 

SUM(TABLA_Pedidos[Precio de Venta]); 
TABLA_Pedidos[Pais]="Peru" 

) 

[Chile]:=CALCULATE( 

SUM(TABLA_Pedidos[Precio de Venta]); 
TABLA_Pedidos[Pais]="Chile" 

) 

[Argentina]:=CALCULATE( 

SUM(TABLA_Pedidos[Precio de Venta]); 
TABLA_Pedidos[Pais]="Argentina" 

) 

[Uruguay]:=CALCULATE( 

SUM(TABLA_Pedidos[Precio de Venta]); 
TABLA_Pedidos[Pais]="Uruguay" 

) 


NOTA 

Tambien hemos 

renombrado la medida 
Colombia Suma de Precio 
de Venta a solo Colombia 
para compactar. 

jIMPORTANTE! 

Crea todas las medidas en 
la tabla pedidos, para ello 
utiliza el cuadro de 
dialogo en medidas en la 
ventana de Excel para 
seleccionar la tabla 
facilmente o, si lo hace 
desde la ventana de 
Power Pivot, crea la 
medida de la siguiente 
forma; Pedidos[Peru], 
Pedidos [Chile],... 


Ahora agreguemos todas las medidas recien creadas al area de 
valores, tambien la medida Suma of Precio de Venta, SKU al area de 
filas con filtro de los elementos que empiezan por la letra C: 
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NOTA 

La diferencia de crear 
medidas para "cada" pais, 
en contra posicion de solo 
anadir el campo pais al 
area de columnas, radica 
en que podemos tener un 
Slicer para pais, y variar 
con el, la medida Suma of 
Precio de Venta, ello 
mantendra las demas 


1 Etiquetas de fila Q 

Colombia 

Peru 

Chile 

Argentina 

Uruguay 

Sum of Precio de Venta 1 

CIO 

$1,910.07 

$2,180.64 

$2,155.42 

1804.591 

1710.578 

$19,387.32 

CM 

$3,042.51 

$2,471.84 

$2,643.04 

3366.9825 

4105.599 

$28,657.67 

CI2 

$1,515.87 

$1,773.99 

$743.02 

1430.828 

1771.004 

$13,765.19 

CI3 

$1,978.01 

$2,050.82 

$2,172.17 

1990.14 

1541.145 

$17,284.29 

CI4 

$1,622.03 

$2,378.58 

$1,439.82 

1885.436 

2602.377 

$18,755.34 

CB0I 

$212,427.20 

$211,472.47 

$192,222.47 

219831.903 

197773.2225 

$1,885,900.62 

CCOI 

$35,326.43 

$33,125.42 

$36,563.51 

35801.8215 

32256.0465 

$313,914.03 

CC02 

$11,004.63 

$12,494.27 

$13,148.91 

12128.208 

11076.776 

$109,568.03 

Total general 

$268,826.75 

$267,948.03 

$251,088.36 

278239.91 

252836.748 

$2,407,232.47 


Figura 8.4- Vista Multiple para un Reporte de Tabla Dinamica 


Hay un moton de situaciones donde este uso es relevante, una 
situacion frecuente es cuando Las ventas para una empresa 


medidas intactas. 


pertenecen a cLases diferentes, ejemplo: Ventas, reemboLso, 


Antes de Power Pivot 
crear un escenario como 
la situacion uno, era 
posible pero no en una 
unica tabla dinamica, en 
aquel entonces tenfamos 
que crear n tablas 
dinamicas (Una para cada 
pais segun la situacion) 
ponerlas todas una al lado 
del otra y ocultar 
columnas para simular la 
situacion presentada, no 
obstante, cualquier 

cambio en las areas de 
colocacion o incluso un 
simple filtro suponfa toda 
una reordenacion. Ahora 
es rapido, facil y 100% 
flexible. 


promocion, contracargo, ventas al por mayor, etc. 

Tasa Basica de Crecimiento 
Situacion 2 

La tasa basica de crecimiento es uno de esos calculos matematicos 
que siempre debemos hacer, pero que en realidad su frecuencia de 
uso es bastante baja. La tasa basica de crecimiento es la diferencia 
entre un valor final e inicial que estan en el tiempo, esto expresado 
como porcentaje del valor inicial. En palabras se puede escuchar 
complejo, sin embargo, la formula matematica es bien sencilla 

Tasa de Crecimiento = (Final - Inicial) / (Inicial) 

Otra formado expresarlo ya que las tasa estan en terminos de 
valores en el tiempo: 


Tasa de Crecimiento = (Presente - Pasado) / (Pasado) 
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De nuestros datos sabemos algo importante: Oue el primer ano de 
actividad de la empresa, con el cual seria tentativo hacer la tasa de 
crecimiento, no es adecuado, puesto que en dicho ano la empresa 
inicio actividad en el ultimo trimestre, por lo que no seria un buen 
punto de referencia. En su lugar el ano 2000 es mucho mas 
apropiado, porque tiene actividad a lo largo de todos los meses y 
lo podemos considerar como ano inicial "completo" de actividad. 

Primero creamos la medida que realice la suma del campo Precio 
de Venta siempre con filtro para el ano 2002: 


TABLA_Pedidos[lngresos Primer Ano Completo 2000]:= 
CALCULATE! [Ingresos]; 

TABLA_Pedidos[Fecha de Envio (ano)]="2000" 

) 


NOTA 

La Medida Precio of Venta 
sabemos en realidad 
representa los ingresos 
segun vimos en el analisis 
exploratorio de tablas en 
el capitulo 4, este nombre 
puede ser enganoso, por 
lo que renombramos de 
ahora en adelante esta 
medida como Ingresos 
(Los usuarios de Excel 2013 
continuen con el mismo 
nombre ya que no se 
actualiza 

automaticamente en las 
medidas en las que Precio 
of Venta esta involucrada). 


Antes de proceder vamos describir la funcion DIVIDE 

La funcion DIVIDE realiza la division dado dos numeros reales y 
retorna BLANI<() si la division es entre cero, por otra parte, podemos 
retornar un valor concreto como:''" o 0, si lo deseamos. 


Funcion 

DIVIDE 


=DIVIDE(<numerador>; <denominador> [;<Resultado Alterno>]) 


Sintaxis 


En la siguiente tabla se detallan sus argumentos: 
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Argumentos de la Funcion DIVIDE 


Argumento 

Description 

Numerador 

Dividendo o numero a dividir. 

Denominador 

Divisor o numero que divide. 

[Resultado Alterno] 

(Optional)^ alor a retornar cuando la division es 
entre 0 lo cual deriva en error, cuando este 
argumento no se especifica retorna BLANKQ 


La funcion DIVIDE es una mejor opcion que realizar la division a lo 
clasico, esto es asi, porque ella nos proporciona la opcion de 
NOTA manejo de errores, en consecuencia, es esta funcion la que 


Crea todas las medidas 
que se han venido 
elaborando en este 
capftulo en la tabla 
TABLA_Pec//c/os, esto 
incluye las medidas 
Ingresos Primer Aho 
completo 2000 y Tasa 
Basica e Crecimiento. 


utilizaremos para crear la medida Tasa de Crecimiento Basico. 


TABLA_Pedidos[Tasa Basica de Crecimiento]:= 

DIVI DE( 

[Ingresos] - [Ingresos Primer Afio Completo 2000]; 
[Ingresos Primer Afio Completo 2000] 

) 


Cuando estes creando la medida anterior, brindale un formato de 
porcentaje con un decimal en el cuadro de dialogo Medidas. 


Enseguida procedemos a realizar un reporte de tabla dinamica que 
tenga el campo Fecha de la tabla Pedidos en el area de filas, y 
llevamos las medidas Ingresos y Tasa Basica de Crecimiento al area 
de valores. Vease como queda la tabla dinamica en la figura 
presentada a continuacion: 
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Etiquetas de fila £] Ingresos 

Tasa Basica de Crecimiento 

El 1999 

$8,685.83 

-95.2 % 

E2000 

$180,680.24 

-0.0 % 

± 2001 

$166,860.36 

-7.6 % 

B2002 

$184,876.83 

2.3% 

f+ 2003 

$177,061.95 

-2.0 % 

B2004 

$168,059.37 

-7.0 % 

+ 2005 

$187,906.44 

4.0% 

±12006 

$ 1 98,797.54 

10.0% 

B2007 

$170,712.79 

-5.5 % 

±2008 

$175,936.37 

-2.6 % 

±12009 

$ 1 98,222.0 1 

9.7 % 

S20I0 

$240,873.82 

33.3% 

±1201 1 

$216,088.04 

1 9.6 % 

±12012 

$229,644.1 3 

27.1 % 

B20I3 

$232,463.65 

28.7 % 

±2014 

$256,692.19 

42.1 % 

B20I5 

$327,323.99 

81.2% 

Total general 

$3,320,885.54 

1 738.0 % 


Figura 8. 5 - Tabla Dindmico con Toso de Crecimiento Bdsico 


Ahora vemos como ha sido el crecimiento de todos los anos 
respecto al ano 2000, lo bueno es que podemos variar dicho ano 
con un par de clics, Por otra parte, si observamos la tabla dinamica 
el valor para el ano 1999, es enganoso porque habiamos hablado 
que este ano empezo tarde, por lo que determinar la tasa de 
crecimiento basica para 1999 carece de sentido, seria entonces, 
removerlo del reporte y asi no desorientar nuestra atencion. 


tComo hacemos que desaparezea el ano 1999 o por lo menos que se 
muestra la celda vacla?- Lo sabemos no es asi. Como vimos en la 
ultima parte del capitulo anterior, una combinacion de las 
funciones IF() y VALUES() nos permite hacer esto. Si no recuerdas 
en que consistia o no te quedo muy claro en aquel momento, te 
recomendamos volver refrescar memoria y comprenderlo al 100%, 
porque ahora simplemente dejamos la medida mas robusta. 
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NOTA 


TABLA_Pedidos[Tasa Basica de Crecimiento]:= 
IF(COUNTROWS(VALUES(TABLA_Pedidos[Fecha de Envio (ano)]))=l; 


Si tienes inconvenientes 
sobrescribiendo la 

expresion para la medida 
Tasa Basica de 
Crecimiento, te 

aconsejamos que elimines 
la medida previa y las 
crees nuevamente 

utilizando la formula DAX 
completa o, consultes el 
compendio de archivos. 


IF(VALUES(TABLA_Pedidos[Fecha de Envio (ano)])="1999"; 
BLANKQ; 

DIVI DE( 


[Ingresos] - [Ingresos Primer Ano Completo 2000]; 
[Ingresos Primer Ano Completo 2000] 

) 

); 

BLANK() 

) 


El reporte de tabla dinamica luciria finalmente de la siguiente 
forma: 


Etiquetas de fila V\ Ingresos 

Tasa Basica de Crecimiento 

ffl 1 999 

$8,685.83 


ffi 2000 

$180,680.24 

-0.0 % 

ffl 2001 

$166,860.36 

-7.6 % 

ffl 2002 

$184,876.83 

23% 

ffl 2003 

$177,061.95 

-2.0 % 

E 2004 

$168,059.37 

-7.0 % 

ffl 2005 

$187,906.44 

4.0 % 

S 2006 

$198,797.54 

10.0% 

ffl 2007 

$1 70,71 2.79 

-5.5% 

ffl 2008 

$175,936.37 

-2.6 % 

ffl 2009 

$198,222.01 

9.7% 

ffl 2010 

$240,873.82 

33.3% 

ffl 20 1 1 

$216,088.04 

1 9.6 % 

ffl 2012 

$229,644.13 

27.1 % 

ffl 201 3 

$232,463.65 

28.7% 

ffl 201 4 

$256,692.19 

42.1 % 

ffl 2015 

$327,323.99 

81.2% 

Total general 

$3,320,885.54 






Figura 8.6- Reporte con Tasa de Crecimiento 
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Tasa de Crecimiento Promedio 
Situation 3 

La tasa basica de crecimiento toma un valor de referenda, 
generalmente el primer ano y realiza el calculo, empero, la tasa de 
crecimiento por intervalos es una manera un poco mas justa para 
ver como ha sido el crecimiento al transcurrir los anos cuando 
tenemos intervalos regulares, para no armar mucho embrollo 
explicando, vamos a tomar su formula directamente: 


Tasade Crecimiento Promedio = 


Presente lr 
Pasodo 


Descrito en palabras seria: La tasa de crecimiento promedio 
consiste en dividir el valor final sobre el valor inicial, despues a 
dicha division elevarla a uno sobre el numero de periodo, para 
finalmente restar uno. (n - numero de periodo en el tiempo). 


iComo resolvemos esta situation? - Te invitamos a que tomes esta 
situacion como un reto para crear tu propia formula DAX, de esta 
manera iras adquiriendo destrezas para realizar expresiones mas 
extensas y asi empezar a dominar el lenguaje DAX de verdad. A 
continuacion, procedemos a crear una expresion que, de solucion 
a la tasa de crecimiento promedio para elaborar una medida, a 
pesar de esto, insistimos en que te tomes un tiempo en pensar y 
encontrar una solucion por tu cuenta, pues es la unica forma de ir 
familiarizandote con las funciones DAX e ir entendiendo su logica, 
"no se aprende a nadar solo mirando las personas en una piscina." 
(Recuerda que tienes las funciones DAX del capitulo 6 y todo lo que 
hemos visto hasta ahora). Solucon 





m 
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Recicla 


Algo que notamos de entrada es que esta situacion tambien debe 
omitir el ano 1999 y empezar desde el 2000, por lo que es 
necesario hacer la misma manipulacion con IF y VALUES, por lo que 
tenderiamos lo siguiente: 


TABLA_Pedidos[Tasa Basica de Crecimiento Promedio]:= 
IF(COUNTROWS(VALUES(TABLA_Pedidos[Fecha de Envio (ano)]))=l; 
IF(VALUES(TABLA_Pedidos[Fecha de Envio (ano)])="1999"; 
BLANI<(); 

Aqui nuestra expresion para la tasa de 
crecimiento por intervalos 

); 

BLANK() 

) 


Ahora debemos preocuparnos por la parte azul que corresponde a 
la formula matematica de tasa de crecimiento promedio, la primera 
parte de la formula, esta: 

I S | 

Presents I 
i Pasado j 


Es bien sencilla, en DAX para nuestro escenario seria: 

DIVI DE( 

[Ingresos]; 

[Ingresos Primer Ano Completo 2000] 
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Ok, pasemos la segunda parte el exponente, es decir esta: 


n 


iComo conseguimos esta parte? el uno es un literal y no hay 
inconveniente, pero que hay de la n. Observemos la tabla dinamica 
donde queremos anadir la medida. 


Etiquetas de fila T Ingreses 

Tasa Basica de Crecimiento 

© 

Queremos que la medida 
para esta celda, la n de la 

±11999 

$8,685.83 


+12000 $180,680.24 


. - 4 

-0.0 % 

◄ -- 

formula tenga el valor de 1 
para este filter context. 

+12001 

$166,860.36 

-7.6 % 


±12002 

$184,876.83 

2.3 % 




±12003 

$177,061.95 

-2.0 % 

\© 



±12004 

$168,059.37 

-7.0 % 

Queremos que la medida 

±12005 

$187,906.44 

4.0 % 


para esta celda, la n dela 
formula tenga el valor de 2 
para este filter context. 

±12006 

$198,797.54 

1 0.0 % 


(±12007 

$170,712.79 

-5.5 % 


(±2008 

$175,936.37 

-2.6 % 



±12009 

$198,222.01 

9.7% 



+J20I0 

$240,873.82 

33.3% 



±1201 1 

$216,088.04 

1 9.6 % 



+12012 

$229,644.13 

27.1 % 



(±12013 

$232,463.65 

28.7 % 



±12014 

$256,692.19 

42.1 % 



+12015 

$327,323.99 

81.2% 



Total general 

$3,320,885.54 





Figura 8. 7 - Analizando Tabla Dinamica para la medida 


Si analizamos podriamos hacer algo de este estilo: 


■ ( 2000 - 2000) +1 = 1 

■ ( 2001 - 2000) +1 = 2 

■ ( 2002 - 2000) +1 = 3 
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tComo detectariamos los numeros en azul?, de hecho, ya lo hicimos 
dado que Las coordenadas para una celda en especifico del filter 
context, arroja el valor del ano, por lo que podemos valernos 
nuevamente de la funcion VALUES, asi: 

VALUES(TABLA_Pedidos[Fecha de Envio (Ano)]) 

Pero es importante resaltar que la funcion anterior devuelve el 
valor como texto, asi: ''2000", "2001", ”2002", etc. Dependiendo de 
La celda, es entonces necesario convertirlo en tipo de dato 
numerico <-Recuerdas alguna funcion de conversion que realiza esta 
tarea ?Si respondiste VALUE, es lo mejor que podriamos escuchar; 
bien, este pedazo de la expresion quedaria asi: 

(VALUE(VALUES(TABLA_Pedidos[Fecha de Envio (Ano)]))) 

Nuestro siguiente paso es organizar estas dos partes de tal manera 
que se ejecute en un orden correcto 




Presente £ "71 r -, 

-pasado i " A (l/(VALUE(VALUES(TABLA_Pedidos[Fecha de Envio (Ano)]))-2000)) 


(DIVIDEC 

[Ingresos]; 

[Ingresos Primer Ano Completo 2000] 
)) 




Con la parte de la expresion DAX anterior ya tenemos todo listo 
para construirla completamente, debemos restar un uno que falta 
de la formula y anadir los parentesis correspondientes para que el 
orden de calculo sea adecuado. 
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TABLA_Pedidos[Tasa de Crecimiento Promedio]:= 
IF(COUNTROWS(VALUES(TABLA_Pedidos[Fecha de Envio (ano)]))=l; 
IF(VALUES(TABLA_Pedidos[Fecha de Envio (ano)])="1999"; 
BLANK(); 

((DIVIDE( 


[Ingresos]; 

[Ingresos Primer Ano Completo 2000] 

) 

) 

A (l/((VALUE(VALUES(TABLA_Pedidos[Fecha de Envio (ano)]))-2000)+l)))-l); 
BLANK() 

) 


La tabla dinamica quedaria: 


Etiquetas de fila t] Ingresos 

Tasa Basica de Crecimiento 

Tasa de Crecimiento Promedio 

E 2000 

$180,680.24 

-0.0% 

-0.0% 

E 2001 

$166,860.36 

-7.6% 

-3.9% 

E 2002 

$184,876.83 

2.3% 

0.8% 

E 2003 

$177,061.95 

-2.0% 

-0.5% 

E 2004 

$168,059.37 

-7.0 % 

-1.4% 

E 2005 

$187,906.44 

4.0% 

0.7% 


E 2006 $198,797.54 10.0% 1.4% 


E 2007 

$170,712.79 

-5.5% 

-0.7% 

E 2008 

$175,936.37 

-2.6% 

-0.3% 


El 2009 $198,222.01 9.7% 0.9% 


El 2010 

$240,873.82 

33.3% 

2.6% 

El 201 1 

$216,088.04 

19.6% 

1.5% 

El 2012 

$229,644.13 

27.1 % 

1.9% 

E20I3 

$232,463.65 

28.7% 

1.8% 

E 201 4 

$256,692.19 

42.1 % 

2.4% 

E20I5 

$327,323.99 

81.2% 

3.8% 

Total general 

$3,312,199.71 




Figura 8. 8- Tabla Dinamica con Tasa de Crecimiento Promedio 
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NOTA 


La creacion 

de 

las 

medidas de 

tasa 

de 

crecimiento, 

tienen 

un 

caracter mas 

academico, 


pues emplenado 

funciones time Intelligence 
con tablas de calendario 
estandar, resolver estos 
escenarios es mas sencillo, 
veremos esto en el 
capitulo 10. 

No obstante, si que 
necesitamos 

manipulaciones de este 
estilo cuando nuestro 
calendario es 

personaliado. 


Lo bonito de realizar las medias con tablas dinamicas como hemos 
venido recalcando a lo largo de todo el libro es que nos sigue 
brindando la flexibilidad de las mismas, por ejemplo, si de la tabla 
dinamica anterior con su medida tasa de crecimiento promedio 
tiene mas sentido para aquellas ventas que no tuvieron ningun 
descuento, entonces con dicha tabla dinamica lo unico que 
debemos hacer es llevar el campo categoria de descuento y realizar 
elfiltro correspondiente. 


Categoria de Descuento Non 


Etiquetas de fila 

g Ingresos 

Tasa Basica de Crecimiento 

Tasa de Crecimiento Promedio 

ffl 2000 

$109,713.23 

0.0% 

0.0% 

Eh) 2001 

$88,002.18 

-19.8% 

-10.4% 

Eh) 2002 

$99,015.86 

-9.8% 

-3.4% 

EH 2003 

$88,055.77 

-19.7% 

-5.3% 

EH 2004 

$86,627.16 

-21.0% 

-4.6% 

EE) 2005 

$163,247.63 

48.8% 

6.8% 

9:12006 

$169,182.79 

54.2% 

6.4% 

ffl 2007 

$89,109.75 

-18.8% 

-2.6% 

Eh) 2008 

$94,868.77 

-13.5% 

-1.6% 

ffl 2009 

$97,818.32 

-10.8% 

-l.l % 

ffl 2010 

$121,078.38 

10.4% 

0.9% 

ffl 201 1 

$109,126.48 

-0.5% 

-0.0% 

ffl 2012 

$126,263.42 

15.1 % 

l.l % 

ffl 2013 

$122,330.33 

11.5% 

0.8% 

ffl 2014 

$128,777.52 

17.4% 

l.l % 

ffl 2015 

$267,541.67 

143.9% 

5.7% 

Total general 

$1,960,759.26 




Figura 8. 9~ Medida Tasa de Crecimiento Promedio con Filtro Non 


Aplicacion de Varios Constrains 
Conjuncion Logica - CALCULATE 

Consideremos en este momento, que deseamos crear una medida 
que nos muestra los ingresos, pero que independientemente de la 
configuracion del reporte, solo tenga en cuenta los que en 
categoria de descuento sean Non y el tipo de compra Normal, ya 
que son considerados ingresos estandar o tipicos. 






















El ADN DE Power Pivot 



La mediada como ya te imaginaras se realiza con CALCULATE, 
aunque, hasta el momento solo hemos trabajo con un solo filtro 
(Constrains), independientemente de ello podemos anadir cuantos 
filtros deseemos ya que estos se comportan como si estuvieran 
dentro de la funcion AND() o Y() de Excel (Conjuncidn idgica) 
Habiendo discutido esto, la creacion de nuestra medida seria: 


TABLA_Pedidos[lngresos Non y Normal]:= 
CALCULATE(SUM(TABLA_Pedidos[Precio de Venta]); 

TABLA_Pedidos[Categoria de Descuento ]="Non"; 
TABLA_Pedidos[Tipo de Compra]="Normal" 

) 


Ahora podemos comparar lado a lado estos dos ingresos, asi 
podemos ver los ingresos cuando se han aplicado descuentos, y 
cuando no. Si anadimos un Slicer de Pais, podemos ver la conducta 
"geografica" iNo es eso estupendo? 


Etiquetas de fila r Ingresos 

Ingresos Non y Normal 

±12005 

$ 1 87,906.44 

$134,609.92 

±12006 

$198,797.54 

$141,475.20 

±12007 

$170,712.79 

$73,039.08 

±2008 

$175,936.37 

$76,715.58 

±2009 

$196,222.01 

$82,515.91 

±2010 

$240,873.82 

$98,734.22 

±201 1 

$216,088.04 

$89,219.69 

±2012 

$229,644. 1 3 

$104,424.86 

±12015 

$232,463.65 

$101,614.41 

±2014 

$256,692.19 

$108,746.44 

±2015 

$327,323.99 

$219,059.01 

Total general 

$2,434,660.96 

$1,230,154.32 



Figura 8.10- To bio Dindmico Ingresos Vs Ingresos Non y Normol 
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Aplicacion con Constrains Alternatives 
Disyuncion Logica Inclusiva - CALCULATE 

Visualicemos un panorama similar, pero con una diferencia en esta 
oportunidad, supongamos que Non o Day Off Full son validos para 
ser considerados como ingresos tipicos. 

Esta vez queremos que la funcion CALCULATE actue como una 
disyuncion logica, es decir, que una serie de filtros se comporten 
como si estuvieran dentro de un OR() u 0() de Excel. <_C6mo hacer 
esto? Solamente debes utilizar un operador logico de Power pivot 
dentro de un argumento filtro y alii hacer las respectivas relaciones, 
la medida seria: 


TABLA_Pedidos[lngresos Tipicos]:= 

CALCULATE! [Ingresos]; 

TABLA_Pedidos[Categoria de Descuento]="A/on" 

|| TABLA_Pedidos[Categoria de Descuento ]= 11 Day Off Full": 
TABLA_Pedidos[Tipo de Compra]="Normal" 

) 


jToma Nota! 



Cuando se utiliza el operador \\ en un unico argumento filtro de la 
funcion CACULATE solamente puede ser utilizados para comparar 
elementos de una misma columna, como la situacion anterior, algo 
de este estllo: TABLA_Pedidos[Tipo de Compra]="Normal" 
TABLA_Pedidos[Pats]="Colombia" no es posible 
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Etiquetas de fila j Ingresos 

Ingresos Tfpicos 

±2005 

$187,906.44 

$137,702.36 

El 2006 

$ 1 98,797.54 

$144,891.85 

±12007 

$170,712.79 

$82,400.44 

El 2008 

$ 1 75,936.37 

$87,222.12 

(±2009 

$198,222.01 

$91,400.74 

(±2010 

$240,873.82 

$( 12,547.12 

±201 1 

$216,088.04 

$102,949.56 

±2012 

$229,644.13 

$1 17,496.62 

±2013 

$232,463.65 

$1 15,414.95 

±2014 

$256,692.19 

$125,581.86 

±2015 

$327,323.99 

$224,799.24 

Total general 

$2,434,660.96 

$1,342,406.88 


Figura 8.11- Toblo Dindmico Ingresos Vs Ingresos Tipicos 


Familia All: ALL, ALLEXCEPT y ALLSELECTED 

Remover Coordenadas del Query Context 


cRecuerdas la etapa dos en el capitulo 7 y la tematica de constrains? 
jPor supuesto que si! Bien como breve resumen: vimos que 
podiamos alterar el query context modificando, agregando o 
removiendo coordenadas, estas constrains vienen empaquetadas 
en una familia de funciones. Es momento de explorar la familia ALL 
y como ellas remueven coordenadas del query context 


Emulando % del Total General 


Vamos a emular el tipo de visualizacion de valor: % del total general 
mediante medidas para estudiar la familia remocion de 
coordenadas, empezaremos por la funcion ALL, esta remueve una 
o mas coordenadas en el query context, vamos directamente al 
ejemplo. 
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Lo que deseamos observar es que porcentaje corresponde los 
ingresos de cada ano respecto al total general, la medida seria: 


Numerador 

(Miembro de la Expresion) 


TABLA_Pedidos[% Ingresos Respecto alTotal]:= 

--___ r ' 

[Ingresos] / 

Denominador 
(Miembro de la Expresion) 

► 

CALCULATE^ ngresos]; 

1 

ALL(TABLA_Pedidos[Fecha de Envio (ano)])) 

_ y 


NOTA 

^Recuerdas la nota del 
capftulo anterior? La cual 
dice que en una expresion 
DAX se pueden aplicar 
diferentes Filter Context a 
distintos miembros de la 
misma. jPues Bien 
Amigo@! Esta emulacion 
nos deja el camino bien 
labrado para aprovechary 
ver porque es esto con 
claridad. Vease el 
esquema de la pagina 
siguiente. 

Ten en Cuenta Tambien: 

En el esquema de la 
proxima pagina se abrevia 
Fecha de Envio (ano) como 
FdE y TABLA_Pedidos 
como Pedidos. 


Creemos una tabla dinamica con la siguiente configuracion: Fecha 
de Envio al area de filas, el campo Pais al area de filtros donde 
seleccionamos unicamente Brasil, y finalmente las medidas 
Ingresos y % Ingresos Respecto al Total al area de valores. 

Pais Brasil „t 


Etiquetas de fila , Ingresos 

% Ingresos Respecto al Total 

IS 1999 

$283.28 

0.08 ?TJ 

0- 2000 

$15,919.51 

4.39% 

S 2001 

$16,374.38 

4.52% 

S 2002 

$19,683.48 

5.43% 

S 2003 

$20,219.66 

5.58% 

S2004 

$14,342.59 

3.96% 

S 2005 

$24,232.53 

6.69% 

0- 2006 

$20,710.53 

5.72% 

S 2007 

$21,157.54 

5.84% 

0- 2008 

$22,829.37 

6.30% 

9 2009 

$22,405.1 1 

6.18% 

S20I0 

$27,657.29 

7.63% 

0-201 1 

$21,847.41 

6.03 % 

S20I2 

$27,132.71 

7.49% 

S20I3 

$23,182.40 

6.40% 

S20I4 

$27,155.50 

7.50% 

0-2015 

$37,169.40 

10.26% 

Total general 

$362,302.68 

100.00% 


Figura 8.12 - Tabla Dinamica Emulando % del Total General 


En la esquematizacion que sigue se analizan los contextos del 
numerador y denominador de la medida % Ingresos Respecto al 
Total, para ver como a distintos miembros de la expresion se aplican 


diferentes filter context. Se analiza el valor 0 . 08 % 
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NUMERADOR: [Ingresos] 

(I): Detector Query Context 


ext 


Pe d i d o 5 [Pais] -'Hrasir 
Ped id os [Fd E] ="/ 999” 


(2) : lExisten Constrains?: NO 

(3) : Construir Filter Context 

En este caso el Query Context paso o ser el Filter 
Context 


ler Filter Context 


Pe d i d o s [Pais]=' Brosff i > 
Pedido5[FdE]=" 1999 


(4): Aplicar Coordenadas 


D 

FdE 1 Q Precio de Venta Q . Q 

Brasil 

iWp ” 

” 25.00 "jj.. 

Brasil 

1999 k 

30.00 |. 

Brasil 

1999 ^ 

23.00 I. 

Brasil 

1999 p 

25.00 J. 

Brasil 

1999 fc 

31.00 ... 

Brasil 

1999 ^ 

39.00 I. 

Brasil 

1999 p 

49.00 |. 

Brasil 

1999 1$ 

49.00 |. 

Brasil 

1999 

49.00 1. 

Brasil 

1999 p 

49.00 |. 

Brasil 

1999 1$ 

49.00 |. 

Brasil 

1999 ^ 

49.00 I. 


(5): Ejecutar Calculo 

SUM(TABLA_Pedidos[Precio de Venta]) 
© SUM(50;56;89;..) 

@ $ 283.28 

* 


DENOMINADOR: CALCULATEf 
(I): Detector Query Context 



(3): Construir Filter Context 

Aqui la funcion remueve cualquier coordenada de FdE, 
dicho de otro modo, quita cualquier filtro del campo FdE 


ter Context 


Ped idos [Pais ]= n RrasiF 


2do Filter Context 


(4,5): Aplicar y Ejecutar 



1 

QFdE 

Q Precio de Venta Q q| 

Brasil 


1999 j$ 

^ 49.00]... 

Brasil 


1999 8$ 

21.001... 

Brasil 


2000 |$ 

23.00J... 

Brasil 


2000 *$ 

25.001... 

Brasil 


2001 |$ 

3I.00|... 

Brasil 


2001 |$ 

39.00*... 

| 

Brasil 


2002 1$ 

49.00j... 

Brasil 


2003 |$ 

2I.Oo!... 


- SUM(TABLA_Pedidos[Precio de Venta]) 
SUM(222;444;..) 

(D $362,302.68 

* 


[Ingresos 


jCALCULATE([lngresos];ALL(TABLA_Pedidos[Fecha de Envio (ano)]) 


(6): Retornar 
0.0008 


Etiquetas de iflla V Ingresos % Ingresos Respecto al Total 
±11999 $283.28 I 0.08 %| 
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Funcion ALL 
Definicion 


Sintaxis 


Argumentos 


Ejemplos 

Validos 


Ejemplos NO 
Validos 



La funcion ALL remueve ciertas coordenadas (filtros) durante las 
etapas del proceso de calculo para una medida. Veamos su sintaxis, 
argumentos y algunas consideraciones. 

ALL(<tabla> | Columna [;Columna] [; Columna]...) 

La funcion ALL tiene un numero indefinido de argumentos: 


Argumentos dela Funcion ALL 

Argumento 

Descripcion 

Tabla 

Una tabla para remover 


coordenadas 

Columna 

columna a quitar Filtro 


El primer argumento de la funcion ALL es obligatorio y puede ser 
una tabla o columna, despues de este se pueden especificar 
cuantas columnas necesitemos siempre y cuando el primer 
argumento no especifique una tabla, es decir, si el primer 
argumento es una tabla, entonces no se pueden especificar 
columnas individuales. Es necesario remarcar que cuando se utiliza 
la funcion ALL es necesario incluir el nombre de la tabla. 

Ejemplos Validos: 

■ ALL(TABLA_Pedidos) 

■ ALL(TABLA_Pedidos[Pais]; TABLA_Pedidos[SKU]) 


Ejemplos NO validos: 

■ ALL(Pais) 

■ ALL(TABLA_Pedidos, TABLA_Pedidos[Pais]) 

■ ALL(TABLA_Pedidos[Paisl;Descuentos[Descuento(%)l) 
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Ahora bien, ya conociendo La funcion ALL, miremos que pasa si 
quitamos eL campo de fecha del area de filas y en su Lugar ponemos 
eL campo Raises sin ningun filtro aplicado, el resultado es este: 


Etiquetas de fila T % Ingresos Respecto al Total 

Argentina 

100 .00% 

Brasil 

100 .00% 

Chile 

100 .00% 

Colombia 

100 .00% 

Ecuador 

100 .00% 

Paraguay 

100 .00% 

Peru 

100 .00% 

Uruguay 

100 .00% 

Venezuela 

100 .00% 

Total general 

100.00% 


Figura 8.13 - Analizando % Ingresos Respecto Al Total 


i_Por que aparece 100% en todas partes de la tabla dinamica? - Si 
analizamos el esquema que elaboramos previamente para el valor 
0.08% de la medida % Ingresos Respecto al Total, vemos que ALL 
solamente esta removiendo la coordenada del campo Fechas de 
Envio (ano) y como podemos apreciar este campo esta ausente, por 
lo cual los dos filter context son exactamente iguales 



Pausemos un Momento 

Es importante que tomes estos escenarios y realices los esquemas 
para distintas situaciones (valores de tabla dinamica) con papel y 
lapiz, de esta manera entenderas e iras interiorizando la tematica de 
los contextos lo cual es el punto clave para ser un Master en el 
lenguaje DAX. jAstque manos a la obra! 
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Optimizando % 
del Total 
General 


Entonces Cual es la manera adecuada de remover todas las 
coordenadas asociada a ana tabla?, visto desde una nueva 
perspectiva, (Cual es la forma correcta de referirse al total general en 
una tabla dinamica? 


",Elemental, mi querido Watson", pues ya vimos que la funcion ALL 
acepta una tabla y con ello remueve todas las coordenadas del 
query context. Actualizando la medida de la siguiente manera. 


Medida 

Reajustada TABLA_Pedidos[% Ingresos Respecto alTotal]:= 

[Ingresos] / 

CALCULATEtflngresos]; 

ALL(TABLA_Pedidos)) 


Una vez reajusta la medida, la tabla dinamica queda: 


Etiquetas de fila w % Ingresos Respecto 

al T otal 

Argentina 

II .48 % 

Brasil 

10.91 % 

Chile 

10.48 % 

Colombia 

11.22% 

Ecuador 

11.24% 

Paraguay 

11.30% 

Peru 

11.27% 

Uruguay 

10.64% 

Venezuela 

11.47% 

Total general 

100.00% 


Figura 8. 14-% Ingresos Respecto ol Total General, Optimo 
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Pausemos un Momento 



Se que estas pensando iPor que molestarse en hacer esto cuando el 
porcentaje del total general es mas fac'd?, pern si lo visualizas a 
profundidad, si deseamos utilizar estos porcentajes en otras medidas 
la opcion clasica de tablas dinamicas no es util. 


Si realizaramos el esquema no encontrariamos coordenadas para 
el filter context, por lo que dicho contexto seria toda la tabla. 

Variaciones para ''Borrar" Filtros 

ALL y sus primos ALLEXCEPT y ALLSELECTED nos permiten remover 
coordenadas de distintos modos. ALLEXCEPT y ALLSELECTED son 
variaciones que nos asisten para poder "movernos", o manipular 
con mayor facilidad las coordenadas que queremos "borrar". Por 
ejemplo, supongamos que deseamos crear una tabla dinamica para 
un tercero donde vea los Ingresos categorizados por anos en el area 
de filas, encima de esto se requiere que el reporte no permita 
filtros de ningun otro tipo exceptuando el de fecha y SKU. 

Una alternativa valida puede ser listar columna a columna en los 
argumentos de la funcion ALL, no obstante, aparte de ser tedioso 
debido a que se tienen que listar 12 campos como mfnimo (Puede 
habercolumnas calculadas) tambien se tendria que anadir de forma 
manual cuando la base de datos crezca y por lo tanto aparezcan 
nuevos campos. La funcion ALLEXCEPT() solventa este 
inconveniente ya que es la variacion de las funciones que nos 

P 0 p rr> i Tq tn ro m r^\ / rnnrrlQn^rl^c ovronfi r Y-\r\<r docn^dnr 
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Funcion ALL 

EXCEPT 

Definicion 


La funcion ALLEXCEPT remueve ciertas coordenadas (filtros) 
durante las etapas del proceso de calculo para una medida, 
excluyendo aquellos campos que especifiquemos. 


Sintaxis 


ALLEXCEPT(<tabla>; Columna;...) 


La funcion ALLEXCEPT tiene un numero indefinido de argumentos 
donde en el primer de ellos indicamos la tabla a remover todos sus 
filtros, a partir del segundo argumento vamos indicando las 
columnas que queremos mantener sus coordenadas. 


Argumentos 

Argumentos de la Funcion ALLEXCEPT 


Argumento 

Descripcion 


Tabla 

Una tabla para remover coordenadas 


columna 

Columna para NO remover Coordenada 


Utilizando la funcion ALLEXCEPT la media quedaria de la siguiente 
manera: 

TABLA_Pedidos[lngresos GENERAL]- 
CALCULATE([lngresos]; 

ALLEXCEPT(TABLA_Pedidos; 

TABLA_Pedidos[Fecha de Envio (ano)]; 
TABLA_Pedidos[SKU] 

) 



seleccionados en la tabla dinamica 


Por otra parte, la funcion ALLSELECTED le brinda dinamismo a un 
reporte, puesto que nos permite detectar parametros 
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Dinamizando % del Total General 

Resulta que nuestra medida % Respecto al Total aun no emula al 
100% el % total general clasico de tablas dinamicas, para ver 
porque vamos a construir una tabla dinamica donde el campo Pais 
vaya al area de filas, las medidas Ingreso y % Ingresos Respecto al 
Total al area de valores, y anadimos un Slicer con el Pais (Todos los 
compos tornados de la tabla Pedidos). Vamos a mostrar la medida 
Ingresos como % del total general de la manera clasica, 
posteriormente procedemos a seleccionar los elementos: 
Argentina, Brasil, Venezuela y Uruguay en el Slicer. 


Pais 


5 = \ 


Argentina 

Brasil 

Chile 

Colombia 

Ecuador 

Paraguay 

Peru 

Uruguay 

Venezuela 



Etiquetas de fila 

B Ingresos % Ingresos 

Respecto al Total 

Argentina 

25.80% 

1 1 .48 % 

Brasil 

24.52% 

10.91 % 

Uruguay 

23.91% 

10.64% 

Venezuela 

25.77% 

11.47% 

Total general 

1 00.00% 

44.50% 


Estas es la medida Ingresos 
presentada como % del total 
general, vemos como reacciona 
de acuerdo a la seleccion en el 
Slicer. 


Nuestro calculo personalizado 
que emula el % del total general 
para la medida ingresos, vemos 
que no reacciona de acuerdo a 
la seleccion en el Slicer. 


Figura 8.15~% Del Total General Clasico Vs % Del Total General (Medida) 


El problema es que la medida % Ingresos Respecto al Total General 
esta ignorando completamente el query context en el 
denominador, por lo que independiente de que elementos esten 
seleccionados en el Slicer va a mantener el valor que se refiere al 
total general y no al "total visible", no obstante, el lenguaje DAX nos 
proporciona una funcion para realizar esto: la funcion 


ALLSELECTED. 
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Funcion 

ALLSELECTED 


Sintaxis 


La funcion ALLSELECTED remueve las coordenadas (filtros) de una 
tabla especificada mantenido aquellas que se han filtrado 
explicitamente. Esta funcion puede ser utilizado para obtener el 
valor total visible. 

ALLSELECTED( [<tabla | Columna>]) 


La funcion ALLEXCEPT tiene un unico argumento donde le 
indicamos tabla a remover todos sus filtros dejando solo aquellas 
coordenadas que se seleccionaron directamente. 


lilBBil 


Argumentos de la Funcion ALLSELECTED 


Argumento Description 

[Tabla \ Columna] Una tabla para remover coordenadas 


Con lo anterior en mente podemos utilizar la siguiente version para 
darle solucion al problema de la tabla dinamica previa y 
proporcionandole mas dinamismo: 


[% Ingresos Total ALLSELECTED]- 
[Ingresos] / 

CALCULATED ngresos]; 
ALLSELECTED(TABLA_Pedidos) 
) 


Ahora podemos anadir esta nueva medida a la tabla dinamica y ver 
como coincide con la funcionalidad clasica de mostrar valores 

rpqnprtn tnt^l crpnpr;}l 
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Pais 


£ \ 


Argentina 

Brasil 

Chile 

Colombia 

Ecuador 

Paraguay 

Peru 

Uruguay 

Venezuela 



Etiquetas de filaQ Ingresos % Ingresos Respecto al Total % Ingresos Total ALLSELECTED 


Argentina 25.80% I 1.48 % 25,80 % 

Brasil 24.52% 10.91% 24.52% 

Uruguay 23.91% 10.64% 23.91% 

Venezuela _ 25.77% _ I 1.47 % _ 25.77% 

Total general I 00.00% 44.50 % I 00.00 % 

Figura 8.16 - Dinamismo a % Del Total General como Medida 


iEUREKA! - AHORA 51 HEMOS LOGRADO LA EMULACION 


ALLSELECTED tiene tres sabores para sus argumentos: 

■ Tabla 

■ Columna 

■ Sin Argumento 


NOTA 

Si anadimos otro Slicer, 
por ejemplo, el campo 
SKU y seleccionamos un 
elemento, vamos a poder 
ver que la medida % 
Ingresos Total 

ALLSELECTED sigue 
teniendo el mismo 
comportamiento que % 
ingresos respecto al total 
general clasico, esto es asf 
gracias a que la funcion 
ALLSELECTED detecta 
automaticamente que 
selecciono el usuario, con 
ello mantiene las 
coordenadas en el filter 
context. 


Cuando se indica una columna se tiene en consideracion 
unicamente la columna especificada para mantener las 
coordenadas dinamicamente, cuando se especifica una tabla 
determinada, ALLSELECTED opera en todas a las columnas de la 
misma, mientras que, si se utiliza sin ningun argumento, es decir, 
de la siguiente manera: ALLSELECTED(), la funcion se aplica a todas 
las tablas en el modelo de datos. 


ALLSELECTED es una funcion "inteligente" que detecta que fue lo 
que selecciono el usuario para mantener las coordenadas 
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Iteracion: SUMX, AVERAGER RANK 

Funciones de Iteracion con Sufijo X 


NOTA 

Las funciones de iteracion 
que tienen el sufijo X 
tambien son de 
agregacion, pero con un 
comportamiento 
ligeramente diferente con 
las que ya estamos 
familiarizados, teniendo 
esto claro, sabemos que 
estas funciones se aplican 
en la quinta etapa en el 
proceso de diagrama de 
flujo. 


Repasemos un tema decisivo aqui sobre Las coLumnas calculadas. 
Sabemos que este tipo de calculo personalizado ocupa espacio en 
memoria porque se crea La columna en la tabla en Power Pivot, por 
Lo que, si tenemos millones de datos y ademas le agregamos una 
gran variedad de coLumnas calculadas, incidira inevitablemente en 
un modelo de datos lento y tedioso de manejar, es decir, minimizar 
las columnas calculadas al menor numero posible repercute en un 
desempeno eficiente. 

Conociendo esto recordemos que la columna Costo Total que se 
determino mediante la suma de Los diferentes costos [Producto, 
Envio, Empaque). iQue tendriamos que hacer para convertir esa 
columna calculada en una medida? jLa solucion salta a la vista! 
^cierto? Con lo que hemos aprendido hasta el momento es sencillo: 


TABLA_Pedidos[Costo Total Medida]:= 

SUM(TABLA_Pedidos[Costo del Producto]) 
+SUM(TABLA_Pedidos[Costo de Envio]) 
+SUM(TABLA_Pedidos[Costo Empaque]) 


Tambien podemos recordar, que la columna calculada Utilidad se 
determino como la diferencia entre la columna Precio de Venta y 
Costo Total, resulta que la Utilidad en realidad es un subtotal, esto 
es asi ya que existe una politica de acuerdo al numero de dias que 
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Transcurrieron desde que el cliente hizo la compra hasta que 
recibe el producto en sus manos. 

Previamente en el capftulo cinco creamos una columna calculada 
con este dato, la cual llamaos Dias de entrega. 

La politica de dias de entrega establece que: de acuerdo al numero 
de dias transcurridos para recibir el producto se realiza un 
descuento respecto al precio de compra (Precio de Venta) para el 
cliente, si demora menos de 120 dias se dice que esta dentro del 
tiempo normal por lo que no hay descuento, si esta entre 120 y 
240 dias se realiza un descuento del 20% respecto al precio de 
compra, si esta entre 240 y 365 un 80%, y cuando es estrictamente 
mayor a 365 se entrega gratis. La tabla resume la politica: 


NOTA 

Vimos como expresar el 
Costo Total como medida, 
a pesar de esto, vamos a 
seguir utilizando la 
columna calculada Costo 
Total para los ejemplos 
que siguen. 



Politicas de Dias de Entrega, Inervalos de Descuento 



# Dias Transc. 


Descuento 

0 

<Dlas de Entrega ^ 

120 

0% 

120 

<D/'os de Entrega ^ 

240 

20% 

240 

<Dlas de Entrega ^ 

365 

80% 


>D/'os de Entrega ^ 

365 

100% 


Loa anterior significa que debemos actualizar la Utilidad de la 
siguiente manera: 


■ ([Precio de Venta ]*0.8)-[Costo Total]) entre 120 y 240 

■ ([Precio de Venta]*0.2)-[Costo Total]) entre 240 y 365 

■ [Costo Total] mayor a 365 


Hacerlo con columnas calculadas es sencillo, sin embargo,... 
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Funcion de 
Iteracion 



... queremos evitar columnas calculadas para no disminuir el 
rendimiento de nuestro modelo de datos, por lo que debemos 
buscar implementar la utilidad actualizada mediante una medida. 

c-Como realizamos esta tarea? 

Si recordamos la sintaxis de la funcion SUM en DAX, tenemos: 

SUM(<Columna>) 

Podemos apreciar que no existe una manera de incluir 
condicionales o alguna alternativa para tener en cuenta los 
descuentos, simplemente la funcion SUM hace la agregacion de la 
columna senalada y no permite ningun otro tipo de accion. 

cCALCULATE?- Hmmmmm! Tampoco, iCierto? 

Hasta este momento en nuestro recorrido no tenemos manera de 
hallar una medida como la especificada, pero no nos aflijamos, las 
funciones de iteracion son un conjunto de elite que nos daran la 
oportunidad de ejecutar calculos como nunca antes. 

Funciones de Iteracion 

Las funciones de iteracion recorren todas las filas en una tabla 
especificada, una a la vez, una por una desde la primera fila hasta la 
ultima en la tabla, en cada paso (Iteracion) la funcion de iteracion 
ejecuta una expresion que sehalemos, esto con el fin de alcanzar 
una meta deseada o retornar un resultado concreto (Esto depende de 
la funcion de iteracion en particular). 
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Vamos a simular lo que hace una funcion de iteracion en una tabla 
de Power Pivot para interiorizar Lo descrito en el parrafo anterior. 
Pero antes, vamos a ver la anatomia de una funcion de iteracion. 


Estructura 

=FUNCION(<Tabla>;<Operaci6n Entre Columnas>) General de una 

Funcion de 
Iteracion 

La estructura presentada la obedecen todas las funciones de 
iteracion, es decir, un nombre y dos argumentos, vamos tomar una 
en especifico, la funcion SUMX de iteracion que tiene la siguiente 
sintaxis: 


=SUMX(<Tabla>;<Expresion>) 


Sintaxis 
Funcion SUMX 


jToma Nota! 


O Las funciones de iteracion terminan con la letra X y todas las 
convencionales tienen su equivalente iterativo, por ejemplo: MINX, 
COUNTX, RANKX, etc. Todas las funciones con sufijo X son de 
iteracion, sin embargo, hay algunas que no tienen una X al final y 
tambien lo son, en un momento veremos porque la distincion. 


Para hacer la simulacion vamos a crear la siguiente medida: 


TABLA_Pedidos[Costo Total lte]:= 

SUMX( TABLA_Pedidos; 

TABLA_Pedidos[Costo del Producto] 
+ TABLA_Pedidos[Costo de Envio] 

+ TABLA_Pedidos[Costo Empaque]) 
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NOTA 

Aquf nuevamente para el 
esquema de la proxima 
pagina se abrevia Fecha 
de Envio (aho) como FdE y 
TABLA_Pedidos como 
Pedidos. 



Ahora creamos una tabla dinamica con La siguiente configuracion: 
EL campo Pai's al area de fiLas, eL campo Tipo de Compra al area de 
fiLtros y seleccionamos el elemento Devolution, eL campo Fecha de 
Envio (aho) tambien al area de fiLtros y seleccionamos el elemento 
2015, un Slicer del campo SKU para filtrar por el elemento L05 y 
medida Costo Total Ite al area de valores (Todos los campos de la 
tabla Pedidos). 




Tipo de Compra Devolution j 

Fecha de Envio (aho) 2015 j 




SKU t= 


|J|Etjquetas de fila 

J Co sto Total Ite 


LG 2 

A 

Argentina 

$42.50 



Brasil 

$44.7*| 


LG 3 


Chile 

$61.40 


LG4 


Colombia 

$47.66 



Ecuador 

$60.34 



Paraguay 

$71.86 



Peru 

$14.36 



Venezuela 

$11.66 



Total general 

$354.54 


Figura 8.17- Tabla Dinamica de Ejemplo para Simular Iteracion 


Para no dejar lugar a confusiones vamos a realizar la 
esquematizacion para el valor $44.76 de la tabla dinamica anterior, 
ya que con este mismo haremos la simulacion en la etapa 
correspondiente en el proceso de diagrama de flujo para el calculo 
de medidas. 
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Medida: Costo Total Ite \ Valor: $44.76 \ Configuration: Tabla Dinamica Figura 8.17 


(I): Detector Query Context 



Query Context 


PedidosfTipo de Compra]="Devdudon” 

Pedidos[FdE]= ,5 20f5 ,! 

Pe d i d o 5 [Pai: 5 ] =”Brasil" 

Pedid05[SKU]=LO.r 





(3): Construir Filter Context 


(2): lExisten Constrains Context?: NO 

Recuerda que no hay ninguna funcion de alteracion (Tabla 
7.1) en la medida, por lo tanto, no hay Constrains 


El Query Context pasa a ser el Filter Context 



(5): Ejecutar Exp res ion jATENCION! 

Aqu\ es donde itera, ya que tenemos la funcion SUMX de iteracion en la medida 


Topo de 

SKU 

Compr^J ^ 

Costo del 

Productcfl 

Costo 

Envio Q 

Costo 

Empaque 

□ 

Pais 

D 

1 Dias de 

Q Entregg 

FdE 

E 

Devolucion L03 

7.99 

3.99 


3 

Brasil 

689 

201! 

Devolucion L03 

7.14 

4.14 


2 

Brasil 

18 

201! 

Devolucion L03 

7.75 

5.75 


3 

d 

Brasil 

950 j 

201! 


Iteration I (Row Context) 



La Operacion en el segundo argumento de la funcion: <Operacion entre Columnas> o 
<Expression> se ejecuta en el Row Context (Fila Actual) - Primera Fila 


7.99 + 3.99 + 3 = 14.98 



Almacena el resultado de la operacion internamente 


Sigue con la proximo Iteracion... 
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Topo de 

Costo del 

Costo 

Costo 


Dias de 


SKU 




Pais 


FdE 

Compr^J 1 

ProductcQ 

Envio Q 

Empaque Q 

□ 

Q Entregg 

□ 


Devolucio 


Devolucion L03 


Devolucion LO 


© 


La Operacion en el segundo argumento de la funcion: <Operacion entre Columnas> o 
<Expression> se ejecuta en el Row Context (Fila Actual) - Segunda Fila 

7.14 + 4.14 + 2 = 13.28 

(d©) Almacena el resultado de la operacion internamente 


U 


Sigue con la proximo Iteracion. 


14.98 


13.28 


Iteracion 2 (Row Context) 


1 Topo de 

1 ^ SKU 

| Comprg 

Costo del 

Productcg 

Costo 

Envio Q 

Costo 

Empaque g 

Pais 

B 

f Dias de 

Q Entregg 

bI 


IUEEB 

UBES 

— 


b^^bsb 

wm 


BHEDS 

BBSS 


■SB 

bbb 

Si 

1 Devolucion L03 

7.75 

5.75 

3 

Brasil 

950 

2015 1 


© 


^2^ Almacena el resultado de la operacion internamente 


L 


14.98 


13.28 


16.50 


Iteracion 3 (Row Context) 


La Operacion en el segundo argumento de la funcion: <Operacion entre Columnas> o 
<Expression> se ejecuta en el Row Context (Fila Actual) - Tercera Fila 

7.75 + 5.75 + 3 = 16.50 


Como ya recorrio todas las filas en el filter context termina la iteracion, ahora toma todos los 
valores almacenados y aplica la funcion, en este caso SUM ya que era la funcion SUMX 



- SUM(14.98;13.28;1650) 

@ 44.76 


(6): Retornar 


|-echa de tnvio (ano^ zu I :> 


LT 



1 Etiquetas de fila 

H Util id ad Total Itel 

Argentina 


$42.50 

Brasil 

| 

$4-4.76 | 

j^-IL -1 _ 


gh f 1 Ai\ 
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Anatomia, Operacion y Descripcion de las Funciones con 
Sufijo X 

Como vimos hace un momento las funciones de iteracion con sufijo 
Xtodastienen la misma anatomia basica: 


= FUNCION(<Tabla>;<Operaci6n Entre Columnas> 


Habiendo hecho una sencilla simulacion en el esquema anterior 
podemos decir como operan: 


■ Toma la tabla en el primer argumento, esta tabla puede ser 
el resultado de una expresion, por ejemplo, 
VALUES(TABLA_Pedidos[Pais]), en cuyo caso la funcion de 
iteracion solo haria el procedimiento por los valores unicos 
del campo pais. 

■ Recorre fila por fila y realiza la operacion en el segundo 
argumento, es decir, opera en el row context. 

■ En cada iteracion almacena el resultado para cuando acabe 
todo el proceso iterativo aplicarle la funcion. 

Como todas las funciones de iteracion, funciona de la misma 
manera, pero lo que cambia es el tipo de agregacion que se hace 
al final del proceso iterativo, se puede decir que ya conocemos el 
funcionamiento de todas las funciones con sufijo X en general, nos 
haria falta listarlas en una tabla y asi ver cuales tenemos 
disponibles. Esto es precisamente lo que vamos a hacer, en la 
siguiente tabla dejamos las funciones X de iteracion organizadas 
con una breve descripcion. 
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Descripcion de Funciones de Iteracion con Sufijo X 

Funcion X 

Description 

SUMX 

Devuelve la suma de una expresion evaluada para cada 
fila. 

AVERAGEX 

Devuelve el promedio aritmetico de un conjunto de 
datos que han sido evaluados para cada fila. 

COUNTX 

Cuenta el numero de valores que tiene numeros en una 
expresion, cuando se evalua en toda la tabla. 

COUNTAX 

Cuenta los NOBLANK en una expresion iterando fila por 
fila. 

MINX 

Devuelve el numero mas pequeno que resulte de la 
evaluation de una expresion que ejecuta fila a fila. 

MAXX 

Devuelve el numero mas grande que resulte de la 
evaluation de una expresion que ejecuta fila a fila. 

PRODUCTX 

Devuelve el producto de una expresion evaluada para 
cada fila. 

STDEVX.P 

Devuelve la desviacion estandar de un conjunto de datos 
que surgen de la evaluation de una expresion fila a fila. 
Utilizada cuando se cuenta con la totalidad de los datos 
(Poblacion -Population-) 

STDEVX.S 

Devuelve la desviacion estandar de un conjunto de datos 
que surgen de la evaluation de una expresion fila a fila 
Utilizada para cuando se tiene un subconjunto del total 
de datos (Muestra -Sample-). 

VARX.P 

Devuelve la varianza de un conjunto de datos que 
surgen de la evaluation de una expresion fila a fila. 
Utilizada cuando se cuenta con la totalidad de los datos 
(Poblacion -Population-) 


CONTINUA.... 
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Continuacion 


Tabla 8.7 Descripcion de Funciones de 
Iteracion con Sufijo X 


VARX.S 

Devuelve la varianza de un conjunto de datos que surgen 
de la evaluacion de una expresion fila a fila Utilizada 
para cuando se tiene un subconjunto del total de datos 
(Muestra -Sample-). 

RANKX 

Devuelve el ranking de un conjunto de numeros que han 
resultado de la evaluacion de una expresion fila por fila. 
(Esta funcion es ligeramente diferente a las demas X) 

MEDIANX 

Devuelve la mediana de un conjunto de datos que han 
sido evaluados para cada fila. 

GEOMEANX 

Devuelve la media geometrica de un conjunto de datos 
que han sido evaluados para cada fila. 

CONCATENATEX 

Concatena el resultado de una expresion que se ha 
evaluado fila por fila. 


Ahora que ya dominamos las funciones de iteracion es tiempo de 
resolver el problema que planteamos al principio de esta seccion, 
calcular la utilidad actualizada, la medida seria asi: 


TABLA_Pedidos[Utilidad Act] 

=SUMX(TABLA_Pedidos; 

SWITCH(TRUE(); 

TABLA_Pedidos[Dias de Entrega]<=129;(TABLA_Pedidos[Precio de Venta])- 
(TABLA_Pedidos[Costo Total]); 

TABLA_Pedidos[Dias de Entrega]<=240;((TABLA_Pedidos[Precio de Venta]*0.8)- 
TABLA_Pedidos[Costo Total]); 

TABLA_Pedidos[Dias de Entrega]<=365;((TABLA_Pedidos[Precio de Venta]*0.2)- 
TABLA_Pedidos[Costo Total]); 

-TABLA_Pedidos[Costo Total] 

) 

) 
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=SUMX(TABLA_Pedidos; 

SWITCH(TRUE(); 

TABLA_Pedidos[Dfas de Entrega]< = 129;(TABLA_Pedidos[Precio de Venta]) -(TABLA_Pedidos[Costo Total]); 
TABLA_Pedidos[Dfas de Entrega]<=240;((TABLA_Pedidos[Precio de Venta]*0.8)-TABLA_Pedidos[Costo Total]); 
TABLA_Pedidos[Dfas de Entrega]<=365;((TABLA_Pedidos[Precio de Venta]*0.2)-TABLA_Pedidos[Costo Total]); 
-TABLA_Pedidos[Costo Total] 

) 


Como Las funciones con sufijo X, evaluan fila por fila en un proceso 
iterativo, podemos incluir una funcion logica en el segundo 
argumento (expresidn) para detectar en que intervalo de dias de 
entrega se encuentra, y operar Los valores especificos para dicha 
fila de precio de venta y de costo. 


En la tabla dinamica que creamos anteriormente (figura 8.17) 
vamos anadir la medida Utilidad Act al area de valores. 


Tipo de Cornpra Devolution |Tr] 
Fee ha de Envio (ano) 2015 t t| 


(fl 

c 

Ill 

H Etiquetas de fila Q Costo Total Ite Utilidad Act 

L02 

A 

V 

Argentina $42.50 $17.48 

Brasil $44.76 $4sTTJ 


L03 

Chile $61.40 $82.55 

Colombia $47.66 $12.32 

<tA.fl 14 _<tlA l 1 ^ 

f L04 


Paraguay 

$71.86 

-$41.87 

Peru 

$14.36 

$14.36 

Venezuela 

$11.66 

$78.31 

Total general 

$354,54 

$143.29 


Figura 8.18 - Tabla Dinamica con la Medida Utilidad Act 


Oueremos dejar esto Lo mas claro posible, asi que a continuacion 
dejamos La esquematizacion para el valor $45.21 que se resalta en 
La figura previa. 
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Medida: Utilidad Act \ Valor: $45.21 | Configuration: Tabla Dinamica Figura 8.1 7 


(/): Detector Query Context 

Query Context 

PedidosfTipo de Compra]='"Devofuddri" 
Pedid0s[FdE]=' 5 2OJ5" 

Pe d i d o s [Pai 5 ] ='’BrasiF 
Pedido5[SKU]=L02" 

(3): Construir Filter Context 


(2): lExisten Constrains?: NO 

Recuerda que no hay ninguna funcidn de alteracion (Tabla 
7.1) en la medida , por lo tanto , no hay Constrains 


El Query Context pasa a ser el Filter Context 

Filtr Context 

-fcPedidosfTipo de Co mpra]=”Devolud6n" 

Pedidos[FdE]=' 3 20/5'’ #- 

Pedidos[Pais]='TB/astf” Q 
Pedidas[$KU]=L03” 


(4): Aplicar y Prop agar 


Tope de 

$KIJ_ 

Costo del 

Costo 

Costo 

Pa'a 

Precio de 

Dias de 

J 

FdM 

1 Com png 

IT- 

ProductcH 

Envio p 1 

Empaque Qj 

D 

Venta Q 

LntregH 


Devolucion 

L03 

7.99 

3.99 

3 ! 

Brasil 

29.99 

689 

2015 

Devolucion 

LO 3 

7.14 

4.14 

21 

Brasil 

89.97 

18 

2015 

Devolucion 

L03 

d 

7.75 

5.75 

. 3 JZ 

Brasil 

59.98 

950 

d 

2015 

d 


(5): Ejecutar Expresion 



Topo de 
Compr^ 

SKU 

□ 

Costo del 

ProducttQ 

Costo 

Envio Q 

Costo 

Empaque 

□ 

Pais 

□ 

Precio de 

Venta Q 

Dias de 

EntregQ 

FdE 

o 

Devolucion 

L03 

7.99 

3.99 


WBM] 

Brasil 

29.99 

689 

2015 

Devolucion L03 7.14 4.14 2 Brasil 89.97 18 2015 

Devolucion 











Iteracion I (Row Context) 



La Operacion en el segundo argumento, esta ocasion la expresion es mas sofisticada - Primera Fila 


SWITCH(TRUE(); 

689<= 129;29.99-14.98; 
689<=240; (29.99*0.8)-14.98; 
689<=365; (29.99*0.2)-14.98; 

-14.98 


FALSO 

FALSO 

FALSO 

VERDADERO 


) 



Almacenar resultado de la operacion 



Sigue con la proximo Iteracion... 
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Topo de 

Q 

SKU 

□ 

Costo del 

ProductcQ 

Costo 

Envio Q 

Costo 

Empaque 

B 

Pais 

I 

Precio de 

3 Venta Q 

Dias de 

Entreg^ 


Devolucion 

L03 





Brasil 




Devolucion 

L03 

7.14 

4.14 


■] 

Brasil 

1 89.97 

18 

2015 


L03 





Brasil 





Iteracion 2 (Row Context) 


0 La Operation en el segundo argumento, esta ocasion la expresion es mas sofisticada - Segunda FL 


Fila 


SWITCH(TRUE(); 

I8<= 129; 89.97- 13.28 ; ... 


VERDADERO 


) 


No ejecuta mas porque ya encontrd el valor VERDADERO 


(© Almacenar resultado de la operation 


U 


- 14.98 

76.69 

[_ 

J 

V 

J 

y 


Costo del Costo 

ProductcH Envio 


Costo 

Empaque 


Precio de Dias de 
Venta Q EntregH 


Iteracion I (Row Context) 


Devolucion L03 


La Operation en el segundo argumento, esta ocasion la expresion es mas sofisticada - Primera Fila 

SWITCH(TRUE(); 

950<= 129;29.99-14.98; FALSO 

950<=240; (29.99*0.8)-14.98; FALSO 
950<=365; (29.99*0.2)-14.98; FALSO 
-16.50 _ 

^2^) Almacenar resultado de la operation ^ ^ 


76.69 

y y 

-16.50 


A 


Como ya recorrio todas las filas en el filter context termina la iteracion, ahora toma todos los 
valores almacenados y aplica la funcion , en este caso SUM ya que era la funcion SUMX 



76.69 


-16.50 


SUM(-14.98;76.69;-16.50) 

© 45.21 


(6): Retornar 


Utilidad Utilidad Act 


167.43 $ 17.48 

135.18 1 $ 45.21 | 
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jToma Nota! 

Con este recorrido ya has podido notar como el filter context y row 
context trabaj'an de la mono, como un equipo, ya que el filter context 
proporciona el conjunto de datos baj'o el cual se debe evaluar la 
medida y ulteriormente el row context proporciona el grado de 
especificacion para que se ejecuten las funciones de agregacion, lo 
cual es mas claro cuando son de iteracion, por lo anterior al filter 
context + el row context se les denomina Evaluation context 
(Contexto de Evaluacion). 


Funcion FILTER 

La funcion FILTER es una funcion de iteracion bien especial, no solo 
por la ausencia del sufijo X, sino porque es una de las funciones de 
"alteracion" del query context que listamos en la tabla 7.1 como 
habra detectado inminentemente el lector mas atento. No 
obstante, la funcion FILTER tiene una manera diferente de alterar 
el query context, pero antes ir a ello vamos a ver su sintaxis y 
fundamentos 

La funcion FILTER del lenguaje DAX devuelve un subconjunto de Definicion 

datos dada una tabla o expresion. 


= FILTER(<tabla>; <filtro>) 


Sintaxis 


La funcion tiene dos argumentos ambos obligatorios, la tabla 
enseguida los especifica 
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Observation 


Ejemplo 




Argumentos de la Funcion FILTER 


Ar gumento Description 

Tabla La tabla a ser filtrada, esta tambien puede ser una 
expresion que retorne una tabla. 


Filtro Una expresion Booleana (VERDADERO/FALSO) 
que sera evaluada fila a fila, ejemplo: 
TABLA_Pedidos[SKU]="LO I" 


Retorna el filter context alterado o visto de otro modo una tabla 
que unicamente contiene las filas filtradas como VERDADERO. 

Sabiendo esto, la funcion FILTER nos permite disminuir el numero 
de filas del query context, o tomar una tabla y filtrarla aun mas, para 
con ello realizar algun tipo de agregacion, algun tipo de calculo. Es 
decir, utilizar la funcion FILTER sola, como: 


FILTER (TABLA_Pedidos; TABLA_Pedidos[Pais]="Uruguay") 

Retorna un error ya que la medida no sabe como resumir la tabla 
para presentarlo como un valor unico en la celda del cuerpo de la 
tabla dinamica, en otras palabras y como vimos en el capftulo 
anterior, la funcion debe estar encapsulada. 



Aterricemos la funcion con un ejemplo, supongamos que sabemos 
que aquellas ventas que tiene un ingreso mayor a $40.00 (Precio 
de Venta) son consideradas ventas de alta rentabilidad, con esto 
queremos conocer el numero de ventas con alta rentabilidad en 
una tabla dinamica que tenga la siguiente configuracion: los 
campos Pais, Tipo de Compra, y Categoria de Descuento ... 

SI 
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... area de filtros con Peru, Normal, Special Day aplicados 
respectivamente; el campo SKU alarea de filas y filtrartodos lo que 
empiecen con la letra L, finalmente dejemos la medida Ingresose n 
el area de valores. 


Pais Peru | t t] 

Tips de Compra Normal 

Categoria de Descuento Special Day j 


Etiquetas de fila 

BIngresos 

LO 1 

$279.83 

L02 

$5-48.73 

L03 

$194.94 

L(M 

$78.26 

LOS 

$474.44 

L06 

$165.95 

L07 

$320.17 

Total general 

$2,062.30 


Figura 8.19- Reporte poro Creor Medida Ventas de Alta Rentabilidad 

La medida Seria: 


[Ventas de Alta Rentabilidad]:= 

COUNTROWS( 

FILTER( TABLA_Pedidos; 

TABLA_Pedidos[Precio de Venta]>= 40 ) 

) 


Cuando se agrega la medida Ventas deAlta Rentabilidad al reporte de la 
figura anterior obtenemos el siguiente resultado. 
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Pais Peru pr| 

Tipo de Cornpra Normal [^| 

Categoria de Descuemto Special Daypr] 


Etiquetas de fila gj Ingresos Ventas de Alta Remtabilidad 


LO 1 

$279.83 


L02 

$3-48.73 

8 

LG 3 

$194.94 

2 

LQ4 

$78.26 


LOS 

$474.44 

7 

L06 

$165.93 

1 

L07 

$320.17 

3 

Total general 

$2,062.30 

21 


Figura 8. 20 - Medido Ventos de Alto Rentobilidod 


Vamos a realizar la esquematizacion para el valor 2 de la medida de 
Ventas de Alta rentabilidad de la tabla dinamica presentada en la 
figura previa y asi no dejar lugar a dudas de la manera en la cual 
opera la funcion de "alteracion" FILTER. 

Podemos lograr realizar la medida anterior de multiples maneras, lo 
cual es una de las grandes bondades del lenguaje DAX, pero aqui lo 
estamos haciendo asi para entender con un ejemplo sencillo el 
funcionamiento de FILTER. 


jToma Nota! 



La esquematizacion siguiente va a cambiar un poco respecto a las 
previas, debido a que en vez de mostrar las coordenadas del query 
context en esta oportunidad vamos a mostrar el query context como 
tal, es decir, la tabla. 
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Medida: Ventas de Alta Rentabilidad | Valor: 21 | Configuration: Tabla Dinamica Figura 820 


(I): Detector Query Context 



Query Context 


Pe d i d o 5 [Pai:5] ='*Pe ru ” 


Pedidos|Tipo de Compra ]- rr Normar 



Pedidos[Categona de De 5 cuenta]- J> Speda/ Day” 



Pedido 5 [SKU]= , IOJ" 




(2) : lExisten Constrains?: SI 

Si observamos la tabla 7. I la cual presente las funciones de alteration principales vemos que 
all\ se encuentra la funcion FILTER Constrains 

(3) : Construir Filter Context: Initial (4): Aplicar y Propagar 



Las Construction del Filter Context aun no ha terminado, de hecho , ahora se itera para disminuir la tabla del 
filter context previo. - jlnicia Iteration! 

Iteration I (Row Context) 


Tipo de 
Compra 

SKU 

B 

Categoria de 

Q Descuento Q 

Precio de 

Pais 

Venta Q 

Normal 

L03 

Special Day 

38.987 Peru 

Normal 

L03 

Special Day 

38.987 Peru 

Normal 

L03 

Special Day 

58.4805 Peru 

Normal 

L03 

Special Day 

58.4805 Peru 
_ 



Se ejecuta Operation en el segundo argumento de la 
funcion 38 987 > = 4Q FALSQ 

No Almacena la fila para devolver la tabla (Un 
nuevo filter context) 


Iteration 2 (Row Context) 


Tipo de 
Compra 

SKU 

□ 

Categoria de 

B Descuento B 

Precio de 

Pais 

Venta | 

Normal 

L03 

Special Day 

38.987 Peru 

Normal 

L03 

Special Day 

38.987 Peru 

Normal 

L03 

Special Day 

58.4805 Peru 

Normal 

L03 

Special Day 

58.4805 Peru 

d 



Se ejecuta Operation en el segundo argumento de la 
funcion gg 9g7 > = 40 FALSO 

No Almacena la fila para devolver la tabla (Un 
nuevo filter context) 


Iteracion 3 (Row Context) 


Tipo de 

SKU 

Compra B 

Categoria de 

B Descuento B 

Precio de 

Pais 

Venta B 

Normal 

L03 

Special Day 

38.987 Peru 

Normal 

L03 

Special Day 

38.987 Peru 

Normal 

L03 

Special Day 

58.4805 Peru 

Normal 

L03 

Special Day 

58.4805 Peru 

1 



Se ejecuta Operacion en el segundo argumento de la 
funcion 58 4805 > = 40 VERDADERO 

Almacena la fila para devolver la tabla (Nuevo filter 
context) 
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Iteration 4 (Row Context) 


Tipo de 

SKU 

CompraH 

Categoria de 

Q Descuento Q 

Precio de 

Pais 

Venta Q 

Normal 

L03 

Special Day 

38.987 Peru 

Normal 

L03 

Special Day 

38.987 Peru 

Normal 

L03 

Special Day 

58.4805 Peru 

Normal 

L03 

Special Day 

58.4805 Peru 


© 

© 


Se ejecuta Operacion en el segundo argumento de la 
funcion 58 4805 > = 40 VERDADERO 

Almacena la fila para devolver la tabla (Nuevo filter 
context) 


Filter Context Definitivo 


Tipo de 

K SK 

Categoria de 

Precio de 

Pais 

CompraQ 

” Descuento p 1 

Venta | ^ 

Normal LG3 

Special Day 

58.4805 Peru 

Normal LG 3 

Special Day 

58.4805 Peru 

_a 


(5): Ejecutar Expresion 


(t COUNTROWS(TABLA_Pedidos[Precio de Venta]) 

© 2 


(6): Retornar - olumna;Z 

( 


En el context actual (Filter Context Definitivo) 


A Resaltar Cosas a Resaltar: Como se puede apreciar en la esquematizacion 

anterior la funcion FILTER supone un cambio ya que se podria decir 
que la construccion del filter context se extiende hasta la etapa 4, 
de ello podemos concluir dos cosas: 

Tenemos funciones que alteran el query context desde las 
columnas, tales son los casos de: ALL, ALLSELECTED, ALLEXCEPT y 
CALCULATE, cuya aplicacion la hacemos en la etapa 2 del proceso 
de diagrama de flujo para el calculo de medidas. 

Por otra parte, tenemos funciones que alteran el contexto desde las 
filas, como el caso de FILTER, cuya aplicacion se hace despues de 
una construccion preliminar del filter context y despues de haberse 
aplicado la etapa 4, pero antes de empezar la etapa 5. 
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Para dejar Las cosas mas claras: Recuerda que en el capitulo 7 
introdujimos el query context el cual consiste en el subconjunto de 
datos que queda despues de aplicar las coordenadas que vienen 
directamente del reporte de tabla dinamica, mientras que el filter 
context son alteraciones al query context mediante restricciones, 
teniendo esto en cuenta podemos ver porque surge un filter 
context inicial, en el esquema anterior cuando utilizamos la funcion 
FILTER, despues de construir dicho contexto inicial se deben 
aplicar otra serie de pasos para disminuir La tabla 


Refrescando y 
Aclarando 
Conceptos 


CALCULATE & FILTER 

El ejemplo de la medida Ventas de Alta Rentabilidad lo podemos 
hacer facilmente con La funcion CALCULATE como ya habra 
advertido mi amigo y lector. 


[Ventas de Alta Rentabilidad]:= 

CALCULATE! COUNTROWS(TABLA_Pedidos); 

TABLA_Pedidos[Precio de Venta]>=40) 


Para ser honesto, la alternativa con CALCULATE es la mas apropiada 
ya que esta funcion aparte de ser una de las mas versatiles por la 
cantidad de escenarios en la que se puede utilizar, esta optimizada 
para ejecutarse de manera mas eficiente que muchas otras 
funciones en el lenguaje DAX, no obstante, hay ciertas 
circunstancias en la cual el uso de filter e incluso FILTER & 
CALCULATE es ineludible. 
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Supongamos que queremos crear una medida que nos indique la 
suma de los costos de producto si estos son estrictamente menores 
que la suma de los costos de envio y empaque. Crear la medida con 
la funcion FILTER por si sola encapsulada en la funcion SUM no es 
posible, por otra parte, podemos tratar con la funcion CALCULATE 
algo de este estilo: 

[Erogaciones Apropiadas de Producto ]:= 

CALCULATE( 

SUM ( TABLA_Pedidos[Precio de Venta] ); 

TABLA_Pedidos; 

TABLA_Pedidos[Costo del Producto] 

< TABLA_Pedidos[Costo de Envio] + 

TABLA_Pedidos[Costo Empaque] 

) 

Sin embargo, una vez escribimos la formula DAX y comprabamos 
vemos que arroja un error: 


Nombredelatabla: 

Mombre de medida: | Erogadones Apropiadas de Producto 
Descripcion: 


Formula: 


fx Comprobar formula 


CALCULATE ( 

SUM ( TABLA_Pedidos[Precio de Venta]); 

TABLA_Pedidos; 

TABLA_Pedidos[Costo del Producto] 

< TABLA_Pedidos[Costo de Envio] + TABLA_Pedidos[Costo Empaque] 

)l 


A 


Calculation error in measure TABLA_Pedidos1Erogaciones Apropiadas de Producto]: The expression contains multiple columns, but only a single column can 
be used in a True/False expression that is used as a table filter expression. 


Figura 8. 21 - Error el orgumentofiltro tiene multiples coordenadas 
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El error se produce porque solamente podemos utilizar en el 
argumento filtro de la funcion CALCULATE una columna de una 
tabla a la derecha y un valor "constante", un escalar al lado 
derecho, algo asi: TABLA_Pedidos[Pais]="Chile", pero varias 
columnas como: TABLA_Pedidos<= TABLA_Pedidos[Costo de 
Envio] no es posible. 

Claro esta situacion tiene solucion, la combinacion CALCULATE- 
FILTER viene al rescate: 


NOTA 

Tampoco podemos 
utilizar medidas en los 
argumentos (filtros) de la 
funcion CALCULATE sin 
importar si la otra parte es 
un escalar. 


[Erogaciones Apropiadas de Producto]:= 

CALCULATE( 

SUM ( TABLA_Pedidos[Precio de Venta] ); 

FILTER ( 

TABLA_Pedidos; 

TABLA_Pedidos[Costo del Producto] 

<TABLA_Pedidos[Costo de Envio]+TABLA_Pedidos[Costo Empaque] 

) 

) 

En esta oportunidad no vamos a realizar la esquematizacion de la 
medida: Erogaciones Apropiadas de Producto, pero visualicemelo en 
nuestras mentes, podemos pensarlo de esta manera: el query 
context es afectado por un constrain en el argumento filtro de la 
funcion CALCULATE, pero este es una funcion FILTER que reduce el 
filter context (debido a que el query context paso a ser el filter context 
inicial) despues de la reduccion y tener el filter context definitivo 
se aplica la funcion. 
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CALCULATETABLE 

Solamente nos hace falta CALCULATETABLE del grupo funciones de 
alteracion (Principales en realidad, ya que ciertamente hay un numero 
mucho mayor) Como puedes intuir CALCULATE trabaja de la misma 
manera que CALCULATETABLE con la diferencia que se ejecuta entre 
la etapa 2 y 4, es decir, la funcion CALCULATETABLE retorna una 
tabla. 


NOTA 

Hay escenarios en los 
cuales la funcion 
CALCULATETABLE es 
necesaria y obligatoria, sin 
embargo, en este capftulo 
no vamos entrar en estos 
detalles ya que el lector a 
medida que vaya 
utilizando el lenguaje DAX 
en el dfa a dfa de su 
trabajo podra ir 
encontrando estas 

circunstancias, y si ha 
estudiado, practicado y 
por lo tanto dominado 
este capftulo, extenderse a 
otras escenarios y 
funciones sera sencillo y 
natural. Por lo tanto, 
asegurate de dominar 
este capftulo a la 
perfeccion. 


CALCULATETABLE(<e><presion>;<filtrol>;<filtro2 >;...) 


La funcion 

CALCULATETABLE tiene un numero indefinido 

argumentos o parametros. 

Argumentos de la funcion CALCULATETABLE 

Argumento 

Description 

Expresion 

La tabla a ser evaluada, ejemplo: TABLA_Pedidos 

Filtro 1 

Una Expresion Booleana o tabla para definir los 
filtros, ejemplos: Pedidos[Pais]="Peru" 

Filtro 2, .. 

Igual que el argumento 1 


Esta seria la version de la medida Ventas deAlta Rentabilidad con la 
funcion CALCULATETABLE. 


TABLA_Pedidos[Ventas de Alta Rentabilidad CALCULATETABLE]- 
COUNTROWS(CALCULATETABLE( 

TABLA_Pedidos; 

TABLA_Pedidos[Precio de Venta]>=40) 
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El Siguiente Paso 

Conociendo el Arte de las Medidasy su aplicacion en la exploracion 
de datos, vamos a seguir profundizando en algunas funciones que 
enriqueceran tu modelo, precisamente las funciones de filtro y la 
versatilidad que proporcionan para construir perspectivas de 
observacion para un mismo reporte. 




La Presente Pagina se ha dejado en Blanco de forma deliberada. 




Capftulo 9 


Funciones de Filtro y Perspectivas del 

Lenguaje 
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Alterando el Row Context: EARLIER 

Iteration Multiple Row Context -Anidacion- 

En el capitulo anterior nos centramos en estudiar las funciones de 
"alteracion" principales: ALL, ALLEXCEPT, ALLSELECTED, 
CALCULATE, CALCULATETABLEy FILTER, que como mencionamos en 
su momento son las primordiales, estas funciones alteran el filter 
context quien esta asociado de manera directa con las medidas. La 
cuestion ahora es iPodemos alterarel row context? 

Como vimos en el capitulo siete, el row context surge de manera 
natural cuando creamos una columna calculada, por ellos vamos a 
decir que el row context generado por columnas calculadas es 
automatico. Por otra parte, vimos en el capitulo ocho como con las 
funciones de iteracion se genera un row context que nos permite 
tomar acciones en dicha fila actual como multiplicar valores. A esta 
manera de crear el row context con iteradores vamos decir que se 
ha creado de forma programable o manual. 

Entones, <- Podemos crear de manera programable multiples 
iteraciones en el row context? Y como ya habras supuesto la 
respuesta es si, hasta el momento esto puede sonar confuso, pero 
vamos a plasmarlo con un ejemplo para entender a que va todo 
esto. 


Iteraciones Anidadas 





Imaginemos que queremos crear una columna calculada que nos 
diga el numero de ventas que tuvieron un mayor numero de 
unidades compradas que el actual. 


Mm imh'M&m 
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Por ejemplo, imagine una tabla con 10 registros, donde La primera 
fila corresponde a una unidad vendida y el resto de filas a 2 
unidades vendidas, entonces nuestra coLumna calculada deberia 
arrojar para la primera fila 9 y para el resto 0. 

iComo reaiizar esta columna calculada? 

Si La columna indicara una constante, por ejemplo, el numero de 
unidades mayores a 2, seria algo sencillo, asi: 

TABLA_Pedidos[Unidades Por Encima]= 

COUNTROWS (FILTER( 

TABLA_Pedidos; 
TABLA_Pedidos[Unidades] >2)) 

Sin embargo, nos piden comparar con el valor de la columna actual, 
algo como esto careceria de sentido: 

TABLA_Pedidos[Unidades Por Encima]= 

COUNTROWS( 

FILTER( TABLA_Pedidos; 

TABLA_Pedidos[Unidades]>TABLA_Pedidos[Unidades])) 


En esencia porque todo devolveria BLANl<(). Si nos detenemos a 
pensar requerimos una iteracion doble, porque necesitamos que 
tome el valor de unidades de la fila actual, por ejemplo, de la fila 1 
y con este haga la comparacion mediante la iteracion fila a fila con 
el valor actual, luego tome el valor de fila 2 y haga la comparacion 
mediante iteracion con todo lo valores de La columna nuevamente 



n 
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Si lo vemos desde el punto de vista de visual basic para 
aplicaciones, podemos visualizarlo como dos bucles For anidados 
que arrojan como resultado: el numero de ventas que tuvieron un 
mayor numero de unidades compradas que el actual. El codigo VBA 
podria ser algo de esta forma: 


NOTA 


Amigo lector, sino tienes 
un conocimiento sobre 
bucles en Visual Basic para 
aplicaciones, el siguiente 
video te pude ser de 
utilidad para adentrarte 
un poco mas en esta 
tematica: 



El Bucle For... Next en 

VBA 


Public Sub SimulacionVBA_EARLIER() 

Dim i As Integer, x As Integer 
Dim ValorActual As Double 
Dim Respuesta As Integer 

Dim ColumnaUnit As Range 
Set ColumnaUnit = Range("Pedidos[Unidades]") 

For i = 1 To ColumnaUnit.Count 

7 * 

ValorActual = ColumnaUnit(i).Value 

/ 

For x = 1 To ColumnaUnit.Count 

If ColumnaUnit.Cells(x).Value > ValorActual Then 
Respuesta = Respuesta + 1 

End If 

Next 

Range("P" & 2 + i).Value = Respuesta 
Respuesta = 0 

Next 


Los dos bucles for, el 
bucle inferno esta 
anidado en el bucle 
for exterior. 


End Sub 
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Pero aun no hemos respondido como dar solucion a este problema 
mediante el lenguaje DAX. 


jDemos to bienvenida la funcion EARLIER! 


La funcion EARLIER nos permite "almacenar" el valor de fila actual 
(Row Context Automatico) y usarlo para comparar o realizar 
cualquier otra operacion mientras se itera en el resto de filas de la 
columna, y asi sucesivamente para cada valor en la columna (Por 
coda valor en la columna itera una vez dicha columna haciendo la 
comparacion u operacion con el valor de la celda donde se esta 
iterando por n-esima vez). 


Definicion 
Funcion EARLIER 


EARLIER(<columna Valor a Mantener>;[<Numero>]) 


Argumentos de la funcion EARLIER 

Argumento 

Descripcion 

Columna 

Una columna que mantendra su valor mientras itera 
en el resto de filas de la columna 

Numero 

Numero de pasos a omitir 


Sintaxis 


Argumentos 



Pausemos un Momento 

Como puedes apreciar la funcion EARLIER tlene dos argumentos, el 
argumento numero representa el numero de pasos o iteraciones a 
omitir, no te preocupes por este parametro ya que su utilization es 
muy poco frecuente, tendiendo a nula. Por otro lado, tenemos la 
funcion EARLIEST quien tambien nos permite jugar con el row 
context, pero tambien es muy raro su uso. 
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Conociendo la funcion EARLIER la formula DAX para la columna 
calculada seria: 


Solucion con 
DAX: EARLIER 


TABLA_Peididos[Unidades por Encima]= 
COUNTROWS( 

FILTER( TABLA_Pedidos; 

TABLA_Pedidos[Unidades] 

> EARLIER(TABLA_Pedidos[Unidades]))) 


Observemosla ya creada en Power Pivot. 


Agregamos la medida 
que determine el maximo 
de la columna Unidades, 


=COUNTROW$( 

FILTER(TABLA_Pedidos; 

TABLA_Pedidos[Unidades]>EARLIER(TABLA_Pedidos[Unidades]))) 

debido a que con esto 


D Unidades 
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Figura 9.1- Columna Calculada con EARLIER 


Complementado 

EARLIER 


Otra forma de ver la funcion EARLIER: La columna calculada se 
define dentro de la tab la Pedidos, la cual genera su row context 
automatico (como vimos al principio del capitulo, visto de otra forma, 
siguiendo el diagrama deflujo de columnas calculadas en el capitulo 
siete). Pero ademas se crea un row context manual ya que se utiliza 
una funcion de iteracion, FILTER, quien como vimos en el capitulo 
ocho genera un filter context por su caracter iterativo. 
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Es decir, que el row context de la funcion FILTER esta anidado 
dentro del row context de la columna calculada, el primero termina 
siendo oculto por el row context mas interno, el de FILTER, esto es 
a si porque FILTER crea un nuevo row context que prima por encima 
de cualquier otro row context. La funcion EARLIER permite 
referirnos al row context previo, dicho de otra manera, al row 
context que se genera automaticamente por la columna calculada. 


Hace referencia al Row 
Context Programable o 
Manual / 


Hace referencia al Row Context 
Programable o Manual 


I 


FILTER(TABLA_Pedidos; TABLA_Pedidos[Unidades] > (TABLA_Pedidos[Unidades])) 


Hace referencia al Row Context Previo, es 
Hace referencia al Row decir, al row context generado 

Context Programable o automaticamente por la columna calculada, 

Manual / esto es asf gracias al funcion EARLIER 

* / 

FILTER(TABLA_Pedidos; TABLA_Pedidos[Unidades] > EARLIER(TABLA_Pedidos[Unidades])) 

Nosotros personalmente, pensamos que la explicacion 
directamente con los row context es mas dificil de entender y 
seguir, por esto, iniciamos la explicacion inicial desde otra visual, 
no obstante, la explicacion con los row context es la que aparece 
en el MSDN y, como se comporta en realidad; por ello la colocamos. 

Recomendamos que se comprenda de esta manera tambien. 


Tomate tu tiempo para interiorizar la funcion EARLIER al 100% asi 
como la existencia de los dos row context, y como esto se puede 
asemejar a una doble iteracion. Entender esto es clave ya que la 


funcion EARLIER tiene un sinfin de escenarios de aplicacion. 
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Funciones de 
Filtro 



Funciones de Filtro 

Ya hemos vistos las funciones de "alteracion" principales, aquellas 
que nos permiten modificar el query context para realizar analisis 
dinamicos mas potentes, ademas, en este capitulo vimos como 
podemos "jugar" con los row context para potenciar aun mas el 
analisis dinamico, en definitiva: 

■ Funciones de "alteracion" -> Filter Context 

■ Funciones para “jugar" -> Row Context (EARLIER & EARLIEST) 

Estas dos denominaciones de categories ("alteracion", "jugar") 
quienes nos permiten manipular los contextos para crear analisis 
dinamicos estan englobados en una categoria mas grande llamada: 
Funciones de Filtro (Filter Functions) y son las mas poderosas y 
complejas del lenguaje DAX. Las que hemos estudiado de esta 
categoria son: 



Funciones de Filtro (Mas comunes -Principales-) 

Funciones 

CALCULATE 

ALL 

ALLEXCEPT 

ALLSELECTED 

CALCULATTABLE 

DISTINCT 


EARLIER 

EARLIEST 

FILTER 

VALUES 
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VALUES Vs DISTINCT 

Puedes notar en La tabla las funciones VALUES y DISTINCT de las 
cuales hablamos, pero no dijimos directamente que eran funciones 
de alteracion, pero si lo piensas en segundo su comportamiento 
brindan precisamente esto, la posibilidad de alterar el query 
context o filter context. 

^Por que?- Recuerda que tanto La funcion VALUES como DISTINCT 
devuelve solamente Los elementos unicos en una columna, y para 
que puedan hacer esto deben alterar la tabla correspondiente del 
filter context 

La diferencia entre DISTINCT y VALUES, es que esta ultima retorna 
BLANK. Veamos el siguiente escenario para aterrizar la diferencia 
entre estas dos funciones. 


Nombre 

T Fecbo 

s 

Monica 


8/2/2016 

Monica 


8/2/2016 

Nicolas 


8/2/2016 

Nicolas 


8/2/2016 

Marta 


4/11/2015 

Marta 


4/11/2015 

Diego 


4/11/2015 

_ A 


Actives-2016 

Monica 

Nicolas 


Etiquetas de fila , Contar con DISTINCT Contar con VALUES 


Monica I I 

Nicolas I I 

(en bianco) I 

Total general 2 3 


Figura 9.2- Escenario para ver diferencia entre VALUES y DISTINCT 




VALUESy 
DISTINCT alteran 
el Filter Context 


Diferencia entre 
DISTINCT y 
VALUES 
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En La figura anterior se puede distinguir facilmente La tabLa matriz y 
La tabLa de busqueda y de que manera estan relacionados, sin 
embargo, dejamos la siguiente imagen. 


□ Busqueda 
E Activos - 2016 


I 

? 


□ Matrix 
HD Nombre 
HD Fee ha 

!& Contar con DISTINCT 
1/j Contar con VALUES 


A 

I 


Figura 9.3- Vista de Diagrama Relacion para ejemplo VALUES Ft DISTINCT 

Las medidas creadas para la tabLa dinamica que se puede ver en La 
parte inferior de La figura de la pagina anterior, son: 


[Contar con DISHNCT]:= 

COUNTROWS(DISTINCT('Busqueda'[Activos - 2016])) 


[Contar con VALUES]- 

COUNTROWS(VALUES('Busqueda'[Activos - 2016])) 


Como se puede apreciar en la tabLa dinamica, VALUES devuelve una 
fila en bianco que surge porque Los elementos: Marta y Diego no 
tienen un elemento coincidente en la tabLa busqueda, por otra 
parte, DISNTINCT devuelve solamente Los valores que existen en la 
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iToma Nota! 



La situation anterior es el unico caso en el cual hay diferencia entre 
DISTINCT y VALUES. Es vital resaltar que si existen BLANK en la tabla 
de busqueda bien sea por una columna calculada o por una medida, 
entonces tanto DISTINCT como VALUES tendran encuentra estos 
BALNK de la misma manera, es decir, no sera ignorado por la funcion 
DISTNICT. 


Somos conscientes de la existencia de DISTINCTCOUNT, pero lo 
previo fue un ejercicio de tipo academico para comprender la 
diferencia entre estas dos funciones. 


Listado de Funciones de Filtro 

Como ya habras notado y podras imaginar las funciones de filtro 
son numerosas, de hecho, las que hemos tratado son tan solo una 
pequena parte de ellas, empero, hemos estudiado hasta el 
momento y comprendiendo las principales, las cuales son las que 
hemos explorado hasta aqui, dadas las herramientas suficientes 
para entender el resto de las funciones de filtro con facilidad para 
cuando las necesitamos. Por lo anterior vamos dejar una lista de 
dichas funciones con una breve descripcion, mas que adentrarnos 
en cada uno de ellas, pues esto seria abrumador. 


Como ya mencionamos, comprender el funcionamiento de las 
funciones de filtro restante es mas intuitivo, y darles un vistazo por 
encima tendras una idea de que tenemos a nuestra disposicion, 
esto para cuando en su momento, dado algun escenario podemos 
acudir a ellas. A continuacion, se listan. 
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Funciones de Filtro 


Funcion 

Description 

ADDCOLUMNS 

Anade una columna calculada a una tabla o 
expresion DAX. 

ADDMISSINGITEMS 

Anade una combination de elementos de multiples 
columnas si estos no existen. 

ALL 

Retorna todas las filas en una tabla ignorado 
cualquier filtro o coordenada. 

ALLEXCEPT 

Retorna todas las filas en una tabla ignorado 
cualquier filtro o coordenada a exception de las 
que se indiquen. 

ALLNOBLANKROW 

Retorna todas las filas en una tabla ignorado 
cualquier filtro o coordenada a exception de 
aquellas que de acuerdo a la relation generan 
BLANK. 

ALLSELECTED 

Retorna todas las filas en una tabla ignorado 
cualquier filtro a exception de aquellos donde se 
selecciono de manera explicita (Por el usuario). 

CALCULATE 

Evalua una expresion de acuerdo a un filter context 
que fue modificado por esta misma. 

CALCULATETABLE 

Retorna una tabla de acuerdo a un filter context 
que fue modificado por esta misma. 

CALENDAR 

Retorna una tabla de una sola columna " fechas" 
que contiene fechas sucesivas, sin exception y 
completamente contiguas, dado que se ha 
especificado una fecha de initio y una final. 

CALENDARAUTO 

Retorna una tabla de una sola columna "fechas" 
que contiene fechas sucesivas, sin exception y 
completamente contiguas, se calcula de acuerdo al 
modelo de datos. 

CROSSJOIN 

Devuelve una tabla que contiene el producto 
cartesiano de todas las filas de todas las tablas de 
los argumentos. 

DISTINCT 

Retorna una tabla de una unica columna que 
devuelve los elementos unicos, es detir, remueve los 
duplicados. 
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Continuacion 

^ Funciones de Filtro 

Funcion 

Description 

EARLIER 

Retornar el valor del row context previo 
especificado para una columna. 

EARLIEST 

Retorna el valor actual de una columna 
especificada proporcionada por una columna en 
particular. 

FILTER 

Retorna una tabla que representa un 
subconjunto de una tabla especificada, dado 
que se acoto de acuerdo a condicionales. 

FILTERS 

Retornar los valores que se utilizaran de manera 
directa para filtrar una columna. 

GENERATE 

Devuelve una tabla que contiene el producto 
cartesiano de una de dos tablas, en el contexto 
de la primera tabla. 

GENERATEALL 

Devuelve una tabla que contiene el producto 
cartesiano de una de dos tablas, en el contexto 
de la segunda tabla. 

GROUPBY 

Devuelve una tabla de resumen, sin hacer 
calculos impllcitos. 

INTERSECT 

Devuelve la interseccion de dos tablas 
manteniendo valores duplicados. 

KEEPFILTERS 

Modifica la forma de aplicar mientras se evalua 
la funcion CALCULATE o CALCULATETABLE. 

RELATED 

Retorna los valores relacionados de otra tabla 
en la tabla actual. 

RELATEDTABLE 

Evalua una expresion (tabla) en un contexto 
que es modificado por el filtro dado. 
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I Continuacion ji 

Funciones de Filtro 

Funcion 

Descripcion 

SAMPLE 

Devuelve una muestra de N filas dada una 
tabla. 

SUMMARIZE 

Devuelve una tabla de resumen. 

SUMMARIZECOLUMNS 

Devuelve una tabla de resumen sobre un 
conjunto. 

TOPN 

Devuelve el Top N en cuantas filas dada una 
tabla. 

UNION 

Retorna la union de dos tablas. 

USERRELATIONSHIP 

Especifica una relacion para ser utilizado en un 
calculo personalizado en particular. 

VALUES 

Retorna una tabla de una unica columna que 
devuelve los elementos unicos, es dear, remueve 
los duplicados. Tambien retorna BLANK. 


Algo mas acerca de las funciones de Filtro 

Para ser honesto la tabla anterior omite algunas funciones de filtro, 
esto para que te hagas la idea de la vastedad de funciones 
avanzadas que tenemos en el lenguaje DAX (sin contar la variedad 
practicamente cosmica de funciones de otras categorias), no se 
omitiran muchas funciones de filtro, sin embargo, es bueno saber 
que aun hay algunas de ellas por alii. 


Por otra parte, la intencion de la tabla no es que las domines 
leyendo esa sencillisima descripcion que se proporciona (En 
algunos casos no dicen mucho, lo sabemos), mas bien, el objetivo de 
listarlas, es que las escanees, para que te hagas una idea de las 
posibilidades y poder acudir y profundizar en las que necesites en 
el dia a dia de tus desarrollos de modelo de datos. 
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jTAMBIEN! Ten en cuenta que a pesar de haber tantas funciones de 
filtro (avanzadas), hasta aqui ya has aprendido una buena parte de 
los conceptos mas complejos en el lenguaje DAX, junto con ello, 
hemos navegado y dominado las funciones mas potentes y con 
mayor probabilidad de utilizar en el desarrollo de modelos de 
datos para nuestro trabajo, clientes o donde lo necesitemos. En 
definitiva, se consciente de que ya empiezas a ser un master en el 
lenguaje DAX. 

Te recomendamos, no obstante, eltercer libro de la coleccion ADN 
de Excel Free Blog: El ADN de Power Bl (.com) y Desktop. Donde 
podras aprender e interiorizar la gran mayoria de las funciones de 
filtro, y asi entrar a la elite de los mas grandes gurus en DAX y 
visualizacion de datos. 


Referenda Cruzada 



LIBRO: EL ADN de Power Bl (com) y Desktop - Miguel Caballero & Fabian 
Torres. Este libro tiene la particularidad que aparte de dedicarse 
fuertemente a visualizacion de datos y Bl, pasa un buen rato en la 
inmersion de las funciones de filtro mas avanzadas (Las funciones de 
tablas complejas) 


jPero Espera! Este libro tiene muchisimo mas que ofrecer, todavia 
falta un mundo de maravillas y extraordinarias fantasias para tomar 
datos y realizar Business Intelligence. Pero antes queremos que 
notes como la tabla previa hace las descripciones de algunas 
funciones haciendo referencia a tablas, esto es algo que esta este 
momento no hemos mencionado directamente. Todo recae en la 
perspectiva desde donde miremos. 
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Perspectivas 


Visto desde 
el Proceso de 
Diagrama de 
Flujo 


Desde Contextos 

Plemos estudiado las distintas funciones en las medidas desde el 
punto de vista del diagrama de flujo y como afectan los diversos 
contextos, que si lo pensamos detenidamente podremos recordar 
que los contextos son tablas y, las funciones de filtro alteran el 
query context o filter context, por lo que podemos verlas como 
funciones que retornan una tabla, es exactamente igual solo que 
visto desde otro angulo de vision. 


Visto como 
Tablas 

Di recta mente 


Desde Tablas 

Tomemos por ejemplo la funcion ALL, en su momento dijimos que 
es una funcion que remueve las coordenadas del query context, 
visto desde tablas, es una funcion que retorna una tabla que resulta 
de la remocion de los filtros de la tabla del query context (Puedes 
ver los diagramas del capitulo 8 y hacer la equivalencia con tablas), 
pero deberia ser intuitivo de forma inmediata, pues recuerda que 
los contextos son tablas, solo que en su momento lo mirabamos 
mas desde el proceso de diagrama de flujo, sino tomate el tiempo 
para interiorizarlo. 


iCuales son los beneficios? 


Hemos enfocado nuestro esfuerzo en el proceso de diagrama de 
flujo ya que cuando lo unimos con la visual desde tablas, podemos 
armar una imagen mas completa del lenguaje DAX. 
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Analogia (Proyecciones Ortograficas) 

Imagi'nalo como vistas de un objeto, por ejemplo, desde eL angulo 
del proceso de diagrama de flujo (contextos) puede ser la vista 
ortografica de frente, mientras que el angulo desde tablas puedes 
ser la vista ortografica de lado. Tomennos por ejemplo un sofa y sus 
vistas como analogia: 


Mode/o 3D Completo \ Lenguaje DAX 



PROYECCIONES 

ORTOGRAFICAS 

Las proyecciones 

ortograficas consisten en 
represar objetos 

tridimensionales en una 
hoja de papel en dos 
dimensiones, la idea es 
mirar el objeto desde un 
angulo determinado y 
representarlo desde ese 
punto de vista, debido a 
que al hacer esto desde 
diversas vistas y 
representarlo en la hoja de 
papel la persona que lo 
puede visualizar en su 
mente el objeto 3d 


Figura 9. 4 - Analogia Proyecciones Ortograficas 


Como puedes apreciar todo esta haciendo referencia a lo mismo, 
desde el punto de vista grafico, para construir el modelo 
tridimensional del "sofa"; lo que hemos hecho es lo mismo, las 
tablas y contextos son exactamente lo mismo, unicamente son 
representaciones para poder construir de forma completa el 
lenguaje DAX y ver cada detalle. jTen en cuenta que nada ha 
cambiado, solo es otra forma de expresar (ver) lo que ya hemos 
estudiado! 
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Transition Context 


jY CALCULATE sigue haciendo de las suyas! 


No por nada, es considerada la mas versatil y magica de las 
funciones en DAX. A que viene esto? Vamos a ver otra de las 
grandes hazanas que podemos lograr con la funcion CALCULATE: 
Transition Context - Transicion de Contextos. 

Conversion de un Contexto a Otro 

Resulta que la funcion CALCULATE nos permite convertir el row 
context en filter context... 



cC 


jAsies! - Has leido correctamente, podemos convertir el row context 
en filter context, es a este proceso al cual se le ha denominado 
Transition Context. 

Empecemos por entender como se realiza, en que consiste y que 
consecuencia pueden surgir derivado de esto, para en un capitulo 
posterior ver porque llega a ser de gran utilidad. En este instante 
hay mencionar que el unico argumento que es obligatorio para la 
funcion CALCULATE es el primero, todos los demas (losfiltros) son 

nnrinn^lpc 




El ADN DE Power Pivot 



Como Realizar Transicion de Contexto 

Vamos a ver esto aplicandolo inmediatamente en Power pivot, 
como la transicion de contexto desde el row hacia el filter, vamos 
a trabajar con columnas calculadas. 

Nos ubicamos en la tabla SKU_Productos y creamos la siguiente 
columna calculada (Nota que es la primera vez que construimos una 
columna calculada en una tabla de busqueda): 


[Suma Agregada lngresos]= 
SUM(TABLA_Pedidos[Precio de Venta]) 


El resultado es el esperado, cada celda de la nueva columna en SKU 
Productos muestra la suma total de la columna Precio de Venta de 
la tabla Pedidos. 


[Suma Agre... T =SUM(TABLA PedidosfPrecio de Venta!) 

A 

s. "bD 

Producto(s) 

Suma Agregada Ing... w 

1 

LOI 

Calculus For Dummies - Mark 

3320885.5 | 

2 

L02 

Calculus, 7th Edition - James 

3320885.5 

3 

L03 

Calculus - Ron Larson 

3320885.5 

4 

5 

UM 

Calculus and Analytic Geometry - George B 

3320885.5 

LOS 

Sears StZemansky's University Physics, Vol. 1 

3320885.5 

6 

LOG 

Sears & Ze man sky's University Physics, Vol. 2 

3320885.5 

7 

L07 

Physics for Scientists and Engineers - Serway 

3320885.5 

8 

9 

L08 

Materials Science and Engineering - Call 

3320885.5 

DO I 

Curso Power Point Pro 

3320885.5 

10 

DO 2 

Curso de Problogging 

3320885.5 

D 1 

DO 3 

Curso de Facebook Ad 

3320885.5 

12 

13 

DQ4 

Curso de Gestion de Actividades 

3320885.5 

BO 1 

Batman Begins 

3320885.5 


Figura 9.5- Columna Suma que Utiliza Columna de Otra Tabla (Igual Comportamiento) 
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Esta fila, la primera, es la 
que se ilustra en la 
esquematizacion de la 
pagina siguiente. El 
proceso que se presenta 
en dicho esquema se 
repite para cada una de 
las filas de manera 
iterativa e independiente 
uno de la otra. 


Como funciona 
el Transition 
Context 



Ahora vamos a crear otra columna calculada, justo al lado de la 
anterior, pero en esta ocasion vamos a encerrar la funcion SUM en 
la funcion CALCULATE, recordando que el primer argumento es el 
unico obligatorio y omitiendo cualquier filtro. 


[Suma Agregada Ingresos CALCULATE]^ 
CALCULATE(SUM(TABLA_Pedidos[Precio de Venta])) 


Pareceria un poco tonto de entrada la columna calculada anterior, 
pero si miramos el resultado: 


™ Agre..£ |=CALCULATE(SUN(TABLA PedidosrPrecio de Vental)) 


S . "oO 

Producto(s) 

Suma Agregada Ingresos CALCULATE v 

LOI 

Calculus For Dummies - Mark 

3320885.5 1| i ” 106404*2 1 

L02 

Calculus, 7th Edition - James 

3320885.5 j 171818.8 

L03 

Calculus - Ron Larson 

3320885.51 78914.2 

L04 

Calculus and Analytic Geometry - George B 

3320885.51 53645.7 

L05 

Sears & Zemansky's University Physics, Vol. 1 

3320885.51 143427.4 

L06 

Sears & Zemansky's University Physics, Vol. 2 

3320885.5 J 55012.9 

L07 

Physics for Scientists and Engineers - Serway 

3320885.5 j 103312.8 

L08 

Materials Science and Engineering - Call 

3320885.51 

DOI 

Curso Power Point Pro 

3320885.51 

D02 

Curso de Problogging 

3320885.5 J 

D03 

Curso de Facebook Ad 

3320885.5 j 

r\A a 

^ - . A . 1 



Figura 9.6- Columna Calculada con CALCULATE que solo usa el primer argumento 


jDiferentes Valores! Oue ha pasado? - Como podras imaginar, 
Transition context 


Basicamente CALCULATE toma el row context (fila actual) lo 
remueve por completo y lo reemplaza por el filter context que tiene 
como coordenadas los equivalentes de las celdas del row context 
removido, lo anterior lo hace para todas las filas iterando. Dicho con 
otras palabras, se aplica un filtro en cada columna correspondiente 
al valor del row context actual. La Esquematizacion enseguida puede 
ayudar a su comprension. 












El ADN DE Power Pivot 



Transition Context Columna Calculada | Suma Agregada Ingresos Calculate 
Tomando la primera fila, el valor: 106404.2 

Pasos I: Remover Row Context Fila I 

Paso 2: Row Context en Filter Context 



Filter Context 




'SKU Prod uctos 1 [Prod ucto (s)]="Gjfcu/us For Dummies -Mark" 






Como se aplico en una tabla de busqueda, entonces aquellas coordenadas relacionadas con la tabla matriz (0 
Tablas Matrices, Puesto que puedo haber mas de una) se propagan esta (s) 

Paso 3: Propagar Paso 4 . Ejecutar 


Tipo de 

SKU 

ComRrlH 

Categoria de 

Q Descuento Q 

Precio de 

Pais 

Venta Q 

Devolution LOI 

Non l" 

92.25 jPeru 

Devolucion LOI 

Non 

L 

93.25 iPeru 

Devolucion LOI 

Non 

94.25 jPeru 

Devolucion LOI 

Non 

95.25 jPeru 


Paso 5: Retornar en la fila de la columna calculada 


SUM(TABLA_Pedidos[Precio de Venta] 

(2) SUM(92.25,92.25 19.875.19.875) 

® |l06404.23 




jToma Nota! 



La esquematizacion anterior, no tiene nada que ver con los procesos 
de diagrama de flujo ni con los esquemas previos, presentamos esto 
aquipara ilustrar de manera grafica el proceso de Transition context 
y poder brindar una forma para comprender e interiorizar este 
concepto. 


Transicion de Contexto Multiples Row Context 


La transicion de contexto ocurre para todos los row context 
actuales, cuando la funcion CALCULATE se ejecuta podemos tener 
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Cree La siguiente columna calcuLada en tabla SKU Productos 
[X Ingresos] = 

SUMX( 'TABLA_CategoriaDeProductos'; 

CALCULATE! 

SUM(TABLA_Pedidos[Precio de Venta]) 

) 

) 

Si analizamos la coLumna calculada, hay un row context de la tabla 
SKU Productos y otro de la TABLA_CategoriaDeProductos. En la 
expresion la funcion SUM dentro de CALCULATE se ejecuta en el 
row context unicamente para una categoria especifica y un 
producto determinado. 



Pausemos un Momento 

La columna calculada X Ingresos produce el mismo resultado que la 
columna calculada Suma Agregada Ingresos CALCULATE, 
esencialmente porque el row context de tabla categoria ya es 
abarcado por el row context de la tabla SKU Productos, empero, la 
medida anterior capta la esencia de multiples row context 


El comportamiento previo es vital porque en este escenario el 
lenguaje DAX tiene un compartimiento singular. Resulta que, si 
utilizamos una medida en el primer argumento de CACULATE, asi: 

[X Ingresos con Medida]= 

SUMX( TABLA_CategoriaDeProductos'; 


CALCULATE! [Ingresos])) 








El ADN DE Power Pivot 



Sabemos que ocurre una transicion de contexto, pero, aquf es 
donde esta La trampa, el meoLlo del asunto, resulta que, si 
utilizamos una medida en multiples row context, entonces no hay 
necesidad de la funcion CALCULATE, es decir la siguiente columna 
CALCULADA: 


[X Ingresos con Medida]= 
SUMX('TABLA_CategoriaDeProductos';[lngresos]) 

La transicion de contexto tambien ocurre. Como dijimos antes es 
algo de ciudad "Medio tramposo del lenguaje DAX" que debe ser 
mencionado y debes tener en cuenta. Esta es la razon por la cual 
se utiliza como convencion poner el nombre de la tabla cuando 
indicamos columnas, pues de esta manera podremos identificar 
con mayor propiedad si esta ocurriendo transicion de contexto. 

El Siguiente Paso 

Para continuar con nuestro viaje por el ADN de Power Pivot, 
inevitablemente, debemos entender que, para construir modelos 
mas precisos y acertados, el manejo de fechas y tiempos es 
necesario, por eso en el capitulo numero 10, conoceras todo lo que 
debes saber sobre Time Intelligence y funciones de Fecha y hora. 



La Presente Pagina se ha dejado en Blanco de forma deliberada. 




Capftulo 10 


Time Intelligence: Calendarios Estandary 

Personalizados 
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Time 

Intelligence 


Tipos de 
Calendarios 


Tablas de Calendario 

Cuando hablamos de analisis de datos e inteligencia de negocios, 
inevitablemente hablamos de dichos analisis o procesos en el 
tiempo, es mas, es raro el caso donde encontremos bases de datos 
que no hagan sus transacciones en fechas especificas o intervalos 
de tiempo determinados, inclusive, el 90% de las tablas siempre 
cuentan con por lo menos un campo de fecha. 

El Lenguaje DAX no es ajeno a ello, por eso trae un paquete especial 
de funciones encaminadas a moldear fechas y permitir reportes 
que de otra manera serian muy dificil de lograr, en ocasiones hasta 
imposibles. Esto es Time Intelligence, una categoria de funciones 
DAX especializadas en: "deflactar, contornear y alabear el espacio 
tiempo"- Ok, Ok, sabemos que no hay espacio para metaforas con 
la relatividad general. Ouisimos intentarlo, no nos juzgues =) 

Pero creo que nos has entendido el punto: Manipular fechas a 
nuestro antojo para crear medietas que encajen en el analisis que 
deseamos. 

Para poder hacer uso de estas funciones, debemos conocer, como 
reza el titulo, las tablas de calendario. Oue son? iDe donde 
obtenerlas?Y Como utilizarlas? Antes de ello, tenemos que decirte 
que existen dos tipos de tablas de calendario: Tablas de Calendarios 
Estandar y Personalizados, ambos son tema de este capitulo, y 
arrancaremos como ya te haz de imaginar por los calendarios 
estandar. 




El ADN DE Power Pivot 


Calendarios Estandar 

La tabla de calendario (en general los dos tipos de tablas de 
calendario) son una especie particular de tablas de busqueda que 
tienen como objetivo permitir categorizar nuestros datos de 
multiples maneras. Veamos una imagen la cual seguramente 
esclarecera que son: 


DateKey M 

Datelnt 1 

Year Key | 

QuarterQfY ear | 

MonthOfYear Q 

1/1/1900 0... 

19000101 

1900 

1 

1 

2/1/1900 0... 

19000102 

1900 

1 

1 

3/1/1900 0... 

19000103 

1900 

1 

1 

4/1/1900 0... 

19000104 

1900 

1 

1 

5/1/1900 0... 

19000105 

1900 


1 

6/1/1900 0... 

19000106 

1900 

1 

1 

7/1/1900 0... 

19000107 

1900 

1 

1 

8/1/1900 0... 

I 9000108 

1900 

1 

1 

9/1/1900 0... 

19000109 

1900 

1 

1 

10/1/1900... 

19000110 

1900 

1 

1 

i m / 1 Ann 

i orinn i i i 

i<sm 

, 

, 


Figura 10.1 - BasicColendarEnglish Importodo de Azure Marketplace 


Okay excelente, pero si es una tabla de busqueda, debe haber un 
Primary Key - ^No es asi? - Y por supuesto, dicha columna con 
valores unicos existe, la columna DateKey contiene las fechas 
desde 1/1/1900 hasta 31/12/2100 de manera consecutiva, un dia 
tras otro, por consiguiente, ninguna fecha se repite y podemos 
tomar esta como clave principal (Porcierto, toda tabla de calendario 
estandar debe tener una columna con estas caracteristicas). 


La tabla de calendario tambien contiene columnas que indican 
ciertos grupos, por ejemplo, para la fecha se puede obtener, aho, 




NOTA 

La tabla de calendario que 
se muestra en la figura 10.1 
fue la que importamos en 
el capitulo cuatro cuando 
estudiabamos como 
obtener datos de Azure 
Marketplace. 

Puedes apreciarla en todo 
su esplendor en la ventana 
de Power Pivot en la hoja 
con nombre: 

BasicColendarEnglish 

jEso es una tabla de 
calendario! 


Primary Key 
(Date Key) 


Grupos 
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Caracterfsticas 

Calendario 

Estandar 


Detengamonos un momento y resaltemos cuales son las 
caracterfsticas de un calendario estandar. 


■ Todos lo meses a excepcion de febrero tienen 30 o 31 dfas. 

■ El mes de febrero tiene 28 dfas y 29 dfas en anos bisiestos 

■ El numero total de dfas del ano son 365 o 364 si el ano es 
bisiesto 

Coloquialmente: El calendario que aparece en tu pc, celular o el que 
tienes fisco al lado de tu computador, ese es el calendario estandar, 
el que usamos dfa a dfa. \El Calendario Gregoriano! 


Propiedades 
Tablas de 
Calendario 
Estandar 


Como ya hemos inferido la tabla de calendario sigue el 
comportamiento del calendario estandar, sin embargo, debemos 
tener en cuentas ciertas caracterfsticas para la tabla: 

■ Debe contener una columna con las fechas consecutivas, 
donde cada fila representa un dfa especifico, generalmente 
llamamos a esta columna: DateKey, Fecha o Fecha Dfa a Dfa. 

■ La columna Fecha debe contener fechas consecutivas sin 
ningun tipo de salto, es decir, incluye sabados, domingos y 
festivos sin excepcion, no importa si no son dfas laborales en 
la empresa. 

■ Las tablas de calendario son tablas de busqueda y, esta debe 
estar relacionada a la tabla matriz (o tablas matrices si 
contamos con mas de una). 




El ADN DE Power Pivot 



■ Grupos: Debe contener columnas que indiquen categories: 
Mes, Semana, etc. 


Que tal una imagen que ilustre las propiedades: 


Columna con Fechas Consecutivas, 


Sin saltos entre fecha y 


Esta tabla de calendario se debe relacionar 

cada fila representa un dia 


fecha. 10,11,12,13,14,15,... 


con la tabla matriz (Mas adelante lo 

determinado 




hacemos). 


© 


© 



| Date Key 2 

Datelnt Q 

YearKey | 

QuarterOfYear | 

MonthOfYear | 

DayOfMonth D 

MonthName Q 

10/12/2100... 

21001210 

2100 

4 

12 

10 

December 

11 /I 2/2100... 

210012II 

2100 

4 

12 

1 1 

December 

12/12/2100... 

21001212 

2100 

4 

12 

12 

December 

13/12/2100... 

21001213 

2100 

4 

12 

13 

December 

14/12/2100... 

21 GO 12 1 4 

2100 

4 

12 

14 

December 

15/12/2100... 

21001215 

2100 

4 

12 

15 

December 

16/12/2100... 

21001216 

2100 

4 

12 

16 

December 

17/12/2100... 

■ ! 

21001217 

2100 

4 

12 

17 

December 

L 

t 





/ 


i 



I 




Todas estas columnas son grupos que derivamos dela columna DateKey, y que podemos 
utilizar para categorizar en los reportes, por ejemplo, el nombre del mes, el numero del mes, 
ano, etc. Etc. Podemos tener cuantas columnas necesitamos, solamente ten presente que es 
mejor poner las necesarias para que el modelo de datos tenga mejor desempeno. 


Figura 10. 2 - llustracion de las Propiedades para las Tablas de Calendario Estandar 



Pausemos un Momento 

A las Tablas de Calendario generalmente se les asigna como nombre: 
Calendario, Fecha o CalendarioALGUNADESCRIPCIONBREVE, pern 
no es obligatorio denominarlas de esta manera, es mas una 
convention para tener claro de que se trata de un tipo de tablas de 
busqueda especial. 
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jToma Nota! 



Una propiedad adiclonal (Optional) para las tablas de calendario, es 
que la fecha de initio deberta ser desde donde tiene operation la 
empresa 14/12/1999 hasta la fecha actual (o la ultima fecha que 
tenga la base) 16/12/2015 y se vaya expandiendo a medida que se 
agregan mas fechas, esta propiedad puede ser especlalmente 
complicada, ya que incluso la nuestra arranca de 1/1/1900 a 31/2100 


Obtener Tablas de Calendario Estandar 

Hay infinidad de fuentes de donde podemos obtener o construir las 
tablas de calendario. Para nuestro caso, la tabla 
BasicCalendarEnglish se obtuvo desde Azure Marketplace, no 
obstante, puede ser incomodo tener los grupos con los nombres en 
ingles como: Monday, January, etc. En dicho caso debemos optar 
por obtener por otro medio la tabla o construirla. Algunas 
Alternativas: 


Fuentes para 
Tablas de 
Calendario 


Azure Marketplace 
Base de Datos: SQL Server 
Construir con Power Query 
Construir en Excel 

Funciones CALENDAR y CALENDARAUTO 



Hasta aqui solamente hemos visto con Azure Marketplace, y la 
verdad no pasaremos tiempo estudiando las otras alternativas, 
puesto que no es el objetivo del capitulo, en su lugar miraremos 
como construir la tabla de calendario en Excel, esta opcion debe ser 
la alternativa mas viable y preferida para el perfil del lector de este 
libro junto con la de Power Query. 









El ADN DE Power Pivot 


Para construir una tabla de calendario estandar en Excel 
empezamos por crear una hoja nueva a la cual llamaremos 
Calendario (Nosotros siempre llamamos a esta tabla: Calendario, sin 
embargo, Fechas, es una opcion muy usada -A las tablas calendario 
tambie se les conoce como Tablas de Fechas) 



Tabla de 
Calendario con 
Excel 


Ponemos los encabezados de columna que necesitemos, para esta 
oportunidad los siguientes: (Por cierto, son lo mas ampliamente 
usados) 


A A BCD E 


G H 


1 

2 

3 

4 

5 

6 


Fecha Ano Mes Numero Mes Nombre Mes Dfa Trimestre Dfa de la Semana Nombre Dfa de la Semana Numero 


Figura 10. 3 - Encabezados para Tabla de Calendario en Excel 


En caso de que no logres leer de manera correcta los encabezados, 
los listamos enseguida en su orden de izquierda a derecha: 

■ Fecha 

■ Ano 

■ Mes Numero 

■ Mes Nombre 

■ Mes Dia 

■ Trimestre 

■ Dia de la Semana Nombre 

■ Dia de la Semana Numero 

Nuestro segundo paso seria identificar la primera fecha y ultima 
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NOTA 

Identificamos la primera y 
ultima fecha para cumplir 
con la propiedad opcional 
mencionada en la nota 
anterior, recuerde que 
esto no es obligatorio, 
aunque, es una buena 
practica ir 

acostumbrandonos e 
incluir las fechas con el 
intervalo de fechas 
necesario. Para que la 
tabla se expanda 
automaticamente 
podemos optar por crear 
un sencillo procedimiento 
en VBA que agregue las 
nuevas fechas cada vez 
que se abra el archivo. 


La primera fecha es: 14/12/1999 y la ultima es: 17/12/2015. 
Procedemos a digitar la primera fecha en la celda inmediatamente 
debajo del encabezado fecha, dejamos la celda activa alii mismo 
para posteriormente dirigirnos a la pestana INCIO, grupo 
MODIFICAR, desplegamos las opciones de relleno y pulsamos clic 
en el comando SERIES. En el cuadro de dialogo que se despliega 
seleccionamos las opciones como se muestra en la siguiente 
imagen: 


Fecha Aho Mes Numero Mes Nombre Mes Dfa Trimestre 


14/12/1999 


Series 


? X 

Series en 

Tipo 

Unidad de tiempo 

O Filas 

O Lineal 

® Fecha 

® Columnas 

O Geometrica 

O Dia laborable 


® Cronologica 

O Mes 


O Autorrellenar 

O Arid 

1 1 Tendencia 

Incremento: 1 

Li'mite: 

17/12/201 5| 


Aceptar Cancelar 





Figura 10. 4 - Serie poro Intervalo de Fechas 


Nota como en el cuadro de texto Lirnite, colocamos la ultima fecha 
de la tabla pedidos, finalmente pulsamos en el boton Aceptar. 


Fecha Aha Mes Numero Mes Nam 

14/12/1999 

I5/I2/I999" 

16/12/1999 

17/12/1999 

18/12/1999 

19/12/1999 

20/12/1999 



to de Fechas creadas con la serie 






















El ADN DE Power Pivot 


Ahora procedamos a convertirla en una tabla estructurada, para 
eUo dejamos la celda activa dentro de la tabla, pulsamos la 
combinacion de teclas Ctrl + T y Aceptar. 


i _ 

Fecha T ] Ana Ales Numero | T J Ales Nombre |V| D/o del Ana [^] Trime 

14/12/1999 

15/12/1999 

16/12/1999 

17/12/1999 

18/12/1999 

19/12/1999 

20/12/1999 

21/12/1999 

22/12/1999 

Tl/ITi/IQ<Kl 

F/gi/ra 10. 6 - Tabla Estructurada para la Creadon de Tabla de Calendario 


Renombremos la tabla como Calendario (Recuerda que con este 
nombre es como aparecera en la hoja de Power Pivot y el cual se 
utilizard para hacer referenda a sus campos). A continuacion, se 
construye cada columna, la siguiente tabla deja las formulas para 
su implantacion. 



Formulas para Construir Columnas en Tabla de Calendario 


Columna 

Funcion 

Ano 

=ANO([@Fecha]) 

Ales Numero 

=TEXTO([@Fecha];"mm") 

Mes Nombre 

=TEXTO([@Fecha];"mmmm") 

Mes D/'o 

=DIA([@Fecha]) 

Trimestre 

=REDONDEAR.MAS(MES([@Fecha])/3;0) 

Dia de la Semana Nombre 

=TEXTO([@Fecha];"dddd") 

Dia de la Semana Numero 

=TEXTO([@Fecha];"d") 






Tabla 

Estructurada 
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NOTA 

No es una mala idea, 
copiar y pegar por valores 
lo construido por las 
formulas, para asf darle a 
cada uno un formato 
apropiado, la primera 
columna: formato fecha, y 
aquellas que representan 
numero que tengan dicho 
formato. Eso no es 
obligatorio, pero es mejor 
hacerlo. 



Asf lucirfa nuestra tabla de caLendario: 


Fecha f7| 

Aho |V| Mes Numero 

|T| Ales Nombre [V] Ales Dfa 

0 

Trimestre [V| Dfa de la Semana Nombre 

|T| Dfa de la Semana Numero [T] 

14/12/1999 

1999 12 

Diciembre 

14 

4 martes 

14 

15/12/1999 

1999 12 

Diciembre 

15 

4 miercoles 

15 

16/12/1999 

1999 12 

Diciembre 

16 

4 jueves 

16 

17/12/1999 

1999 12 

Diciembre 

17 

4 viernes 

17 

18/12/1999 

1999 12 

Diciembre 

18 

4 sabado 

18 

19/12/1999 

1999 12 

Diciembre 

19 

4 domingo 

19 

20/12/1999 

1999 12 

Diciembre 

20 

4 lunes 

20 

21/12/1999 

1999 12 

Diciembre 

21 

4 martes 

21 

22/12/1999 

1999 12 

Diciembre 

22 

4 miercoles 

22 

23/12/1999 

1999 12 

Diciembre 

23 

4 jueves 

23 

24/12/1999 

1999 12 

Diciembre 

24 

4 viernes 

24 

25/12/1999 

1999 12 

Diciembre 

25 

4 sabado 

25 

26/12/1999 

1999 12 

Diciembre 

26 

4 domingo 

26 

27/12/1999 

1999 12 

Diciembre 

27 

4 lunes 

27 

28/12/1999 

1999 12 

Diciembre 

28 

4 martes 

28 

29/12/1999 

1999 12 

Diciembre 

29 

4 miercoles 

29 

30/12/1999 

1999 12 

Diciembre 

30 

4 jueves 

30 

31/12/1999 

1999 12 

Diciembre 

31 

4 viernes 

31 

1/1/2000 

2000 01 

Enero 

1 

1 sabado 

1 

2/1/2000 

2000 01 

Enero 

2 

1 domingo 

2 

3/1/2000 

2000 01 

Enero 

3 

1 lunes 

3 

4/1/2000 

2000 01 

Enero 

4 

1 martes 

4 

5/1/2000 

2000 01 

Enero 

5 

1 miercoles 

5 

6/1/2000 

2000 01 

Enero 

6 

1 jueves 

6 

7/1/2000 

2000 01 

Enero 

7 

1 viernes 

7 


Figura 10. 7 -Tabla Calendario Final desde Excel 


Procedemos a agregar la tabla de calendario a Power Pivot, una vez 
hecho esto vamos a la vista de diagrama. 


ES TABLA_Cate... 

IS Descuentos 

ES SKU Productos 

ei sku 

ES Descuento (%) 

ES SKU 

ES Categorfa 

El Categorfa de Descuento 

El Producto(s) 

El Precio de Venta 


ES Suma Agregada Ingr... 



El Suma Agregada Ingr... 


I 


El Calendario 


El Fecha 

1 

ES Ano 

j 

El Mes Numero 


ES Mes Nombre 



-o- 


♦ * * 

ES TABLA_Pedidos 
ES Numero de Pedido 
ES Tipo de Compra 
ES SKU 

IS Categorfa de Descuento 
ES Precio de Venta 
ES Unidades 

n r'ftrtn rial Drnrli irfn 




Figura 10.8- Vista de Diagrama con Tabla de Calendario de Excel 
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Como discutimos hace un momento las tablas de calendario son 
tablas de busqueda que se deben relacionar con las tablas 
matrices, para nuestro caso la tabla de calendario, Calendario, se 
debe relacionar con la tabla Pedidos. Sabemos que en la tabla 
calendario la columna a vincular es el campo Fecha (Primary Key), 
no obstante, cuando observamos la tabla Pedidos podemos 
apreciar que tenemos dos campos de fecha: Fecha de Envio y Fecha 
de Llegada; Aqui surge la pregunta: 

(Con cadi de los dos campos se deberia relacionar estas dos tablas? 
La respuesta: Depende. 

(Mas detalle? 


Depende ya que, si queremos basar nuestro analisis en las fechas 
en las cuales el cliente recibe el producto, entonces, la relacion con 
el campo Fecha de Llegada es la indicada, por otra parte, si nuestro 
analisis se basa en la Fecha de Envio, el cual tiene las caracteristicas 
de ser la fecha de compra, entonces la relacionamos con este 
ultimo campo. 

Tal vez, la primera opcion que se te ha ocurrido mi amigo, fue 
relacionar el campo fecha con el campo Fecha de Envio, pues dicho 
escenario es de mayor factibilidad, dado que basar nuestros 
analisis con la " Fecha de Compra" es una de las opciones mas 
usadas. Alternativamente, utilizar la opcion con Fecha de Llegada 
tambien es perfectamente valido, dado que con ello podemos 
realizar otro tipo de analisis. Por el momento relacionaremos Fecha 


NOTA 

De pronto se te haya 
ocurrido crear las dos 
relaciones y crear medidas 
con una relacion u otro o 
con ambas. Lo cual, /es 
una gran idea! Veremos 
como llevar acabo tal 
tarea en un capftulo 
posterior, por el momento 
una unica relacion entre 
dos tablas. 



con Fecha de Envio. 
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Relacionando Las tablas en La vista de diagrama: 


HU TABLA_Cate... 

US Descuentos 

SB SKU Productos 

m sku 

SB Descuento (%) 

bb sku 

OB Categorfa 

EfS Categorfa de Descuento 

El Producto(s) 

SI Precio de Venta 


SB Suma Agregada Ingr... 



El Suma Agregada Ingr... 


I 


IS Calendario 


( m Fecha | 


SB Ano 


IB Mes Numero 


SB Mes Nombre 



S3 TABLA_Pedidos 
I~1 Numero de Pedido 
SB Tipo de Compra 

□ SKU 

□ Categorfa de Descuento 

□ Precio de Venta 

□ Unidades 

□ Costo del Producto 

□ Costo de Envio 

□ Costo Empaque _ 

| D Fecha de Envio _ 

□ Fecha de Llegada 

□ Pafs 


Figura 10. 9 - Relation Campo Fecha con Campo Fecha de Envio 


Las tablas de calendario se comportan como cualquier tabla de 
busqueda, con Lo cual podemos usar sus campos de La manera como 
hemos venido trabajando, por ejemplo, podemos llevar el campo 
Ano de tabla Calendario al area de filas y la medida ingresos al area 
de valores 


Etiquetas de flla ▼ Ingresos 

1999 

$8,685.83 

2000 

$ 1 80,680.2-4 

2001 

$166,860.36 

2002 

$184,876.83 

2003 

$177,061.95 

2004 

$168,059.37 

'inn'; 

<t 1 Q7 004 AA 


Figura 10.10 - Campos de la Tabla Calendario Trabajan como Cualquier Tabla de Busqueda 
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Time Intelligence Vs Funciones de Fecha y Hora 

Time Intelligence son un grupo bastante especial de funciones ^Quesonlas 

dentro de la categoria de funciones de fecha y hora, porque se funciones Time 

ajustan y operan para fechas que estan cambiando 

constantemente, dependiendo del contexto en el reporte de tabla 

dinamica, por supuesto, la majestuosidad de time Intelligence es 

que nos permite manipular el query o filter context, ya sabes, como 

todo poder rnitico del lenguaje DAX. 


Por lo anterior, time Intelligence no tiene ningun equivalente con n 0 tj e rie Sunil 

las funciones de fecha y hora en Excel, ni siquiera caracteristicas en Excel 

parecidas, pero, no dejan de ser funciones de fecha y hora, de 
"elite", si, pero se encuentran agrupadas en la categoria de 
funciones de fecha y hora en Power Pivot. 


Para nuestro gusto seria bastante bueno separar las funciones time 
Intelligence de las funciones de fecha y hora clasicas, pero no es el 
caso en Power Pivot, lo importante, a pesar de ello, es que nosotros 
somos conscientes de esta diferenciacion; incluso, podemos 
buscar en google: time Intelligence in DAXy podremos encontrarlas 
en el MSDN agrupadas en su propia categoria. 


Marca Tabla como Calendario 

Para no tener inconvenientes con la utilizacion de las funciones 
Time Intelligence, debemos decirle explicitamente a Power Pivot 
cuales tablas es de calendario, para ello, estando posicionados en 
dicha tabla en la ventana de Power Pivot, nos dirigimos a la pestaha 
DISENOS, luego de eso ubicamos el grupo CAELNDARIOS ... 
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Y clicamos encima de la opcion: MARCAR COMO TABLA DE FECHAS. 


}S QI J C* - 

Herramientas de tabla 

File 

Inicio Diseno Avanzadas 

Tabla vinculada 


Power Pivot para Excel - Capitulo 10 (Final).xlsm 


Agregar 


li?? Eliminar 
m Inmovilizar * 
PP Ancho 
Columnas 


fx 


BUS 


m 




Insertar Opciones 
funcion de calculo T 


Crear Administrar 
relation relaciones 


Propiedades 

detabla 


Marcar como Tabla de 
tabla de fechas fechas ▼ 


Deshacer 
C* Rehacer 


Marcar como tabla de fechas 


[Di'a de la S. 


| .g? Configurp 



■ra 

Ano D 

Mes Numero 

D Mes Nombre Q MesDia 

D Trim* 

1 

14/12/1... 

1999 

12 

Diciembre 

14 


Marque la tabla seleccionada como 
una marca de fechas para habilitar 
el filtrado de fechas espetifico en 
los informes que crea en 
aplicaciones como Excel. 




2 15 / 12 / 1 ... 


1999 12 


Diciembre 


4 miercoles 


Figura 10.11- Marcar Tabla como Calendar!o 


Funciones DAX Time Intelligence 


Hay una buena cantidad de funciones DAX Time Intelligence, lo 
primero que vamos a hacer es listarlas y describirlas muy 
brevemente. 


Funciones DAX Time Intelligence 


Funcion 

Descripcion 

CLOSINGBALANCEMONTH 

Evalua una expresion en la ultima fecha del 
mes del contexto actual. 

CLOSINGBALANCEQUARTER Evalua una expresion en la ultima fecha del 

trimestre del contexto actual. 

CLOSINGBALANCEYEAR 

Evalua una expresion en la ultima fecha del 
ano del contexto actual. 

DATEADD 

Retorna una tabla que contiene columna de 
fechas, desfasada bien sea hacia adelante o 
atras en el tiempo. 



a 


“MB 
















Continuacion 


Funciones DAX Time Intelligence 


Funcion 

Descripcion 

DATESBETWEEN 

Retorna una tabla que contiene columna de fechas, 
dado que se especifica una fecha inicial y final (Pueden 
ser expresiones). 

DATESINPERIOD 

Retorna una tabla que contiene columna de fechas, 
dado que se especifica una fecha y continua en un 
intervalo especificado. 

DATESMTD 

Retorna una tabla que contiene una columna con las 
fechas desde el primer dia del mes hasta la fecha 
actual, por ejemplo, si la fecha es: 16/212016 devuelve 
las fechas del 112/2016 hasta 16/212016, todo eso en 
el contexto actual 

DATESQTD 

Retorna una tabla que contiene una columna con las 
fechas desde el primer dia del trimestre hasta la fecha 
actual, por ejemplo, si la fecha es: 07II212015 
devuelve las fechas del 1121012015 hasta 

07/1212015, todo eso en el contexto actual 

DATESYTD 

Retorna una tabla que contiene una columna con las 
fechas desde el primer dia del aho hasta la fecha 
actual, por ejemplo, si la fecha es: 21/11/2015 
devuelve las fechas del 1/112015 hasta 21/12/2015, 
todo eso en el contexto actual. 

ENDOFMONTH 

Retorna la ultima fecha del mes en el contexto actual 
para la columna de fecha especificada. 

ENDOFQUARTER 

Retorna la ultima fecha del trimestre en el contexto 
actual para la columna de fecha especificada. 

ENDOFYEAR 

Retorna la ultima fecha del aho en el contexto actual 
para la columna de fecha especificada. 


Retorna la primera fecha en el contexto actual para 
una columna de fecha especificada. Esta funcion la 
podemos visualizar como la funcion MIN para valores 
de tipo fecha. 


FIRSTDATE 
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Continuacion 


Funciones DAX Time Intelligence 


Funcion 

Description 

FIRSTNOBLANK 

Retorna la primera fecha en el contexto actual 
para una columna de fecha especificada. Donde 
la expresion no es BLANK 

LASTDATE 

Retorna la ultima fecha en el contexto actual 
para una columna de fecha especificada. 

LASTNOBLANK 

Retorna la ultima fecha en el contexto actual 
para una columna de fecha especificada. Donde 
la expresion no es BLANK 

NEXTDAY 

Retorna una tabla que contiene una columna con 
todas las fechas desde el dia siguiente, basado en 
la primera fecha especificada en la columna 
fecha en el contexto actual. 

NEXTMONTH 

Retorna una tabla que contiene una columna con 
todas las fechas desde el mes siguiente basado 
en la primera fecha especificada en la columna 
fecha en el contexto actual. 

NEXTQUARTER 

Retorna una tabla que contiene una columna con 
todas las fechas desde el trimestre siguiente 
basado en la primera fecha especificada en la 
columna fecha en el contexto actual. 

NEXTYEAR 

Retorna una tabla que contiene una columna con 
todas las fechas desde el aho siguiente basado 
en la primera fecha especificada en la columna 
fecha en el contexto actual. 

OPENINGBALANCEMONTH 

Evalua una expresion en la primera fecha del 
mes del contexto actual. 
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Continuacion *J|j 

Funciones DAXTime Intelligence 

Funcion 

Description 

OPENINGBALANCEQUARTER Evalua una expresion en la primera fecha del 

trimestre del contexto actual. 

OPENINGBALANCEYEAR 

Evalua una expresion en la primera fecha del 
mes del contexto actual. 

PARALLERLPERIOD 

Retorna una tabla que contiene una columna 
de fechas que representan el periodo paralelo 
a la fecha especificada en la columna fecha 
en el contexto actual, dado que las fechas se 
desfasa en un intervalo determinado. 

PREVIOUSDAY 

Retorna una tabla que contiene una columna 
de fecha de todas las fechas representando el 
dla previo hasta la fecha indicada en su 
argumento fecha. 

PREVIOUSMONTH 

Retorna una tabla que contiene una columna 
de fecha de todas las fechas representando el 
mes previo hasta la fecha indicada en su 
argumento fecha. 

PREVIOSQUARTER 

Retorna una tabla que contiene una columna 
de fecha de todas las fechas representando el 
trimestre previo hasta la fecha indicada en su 
argumento fecha. 

PREVIOUSYEAR 

Retorna una tabla que contiene una columna 
de fecha de todas las fechas representando el 
aho previo hasta la fecha indicada en su 
argumento fecha. 

SAMEPERIODLASTYEAR 

Retorna una tabla que contiene una columna 
de fechas desfasada un aho adelante o atras 
respecto a la fecha especificada en el 
argumento de la funcion. 
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Continuacion 


Funciones DAX Time Intelligence 


Funcion 

Description 

TOTALMTD 

Evalua una expresion para una fecha desde 
el inicio del mes hasta la fecha actual. 

TOTALQTD 

Evalua una expresion para una fecha desde 
el inicio del trimestre hasta la fecha actual 

TOTALYTD 

Evalua una expresion para una fecha desde 
el primer dia del aho hasta la fecha actual 


Familias de Funciones Time Intelligence 

Como podemos apreciar en la tabla, la cantidad de funciones time 
Intelligence es abrumadora, de hecho, algunas de sus descripciones 
son confusas si no se tiene claro las bases teoricas de contexto, 
incluso, si se tiene claro algunas de ellas aun pueden sonar 
ambiguas y enredadas; lo anterior es asi, basicamente porque 
algunas de ellas son mucho mas complejas describirlas con 
palabras que comprender lo que realmente hacen. 


La solucion, ver una por una de manera detallada. Sinceramente, 
eso seria una tarea para un libro completo. 

La buena noticia es que todas esas funciones se pueden categorizar 
en subgrupos mas pequenos por afinidad, ya que tienen un 
comportamiento similar, con tan solo cambios menores que se 
pueden extrapolar sin ningun problema. 
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DATESYTD, DATESMTD & DATESOTD 

Este trio dinamico de funciones retorna una tabla con las fechas 
desde el principio del ano, mes o trimestre hasta el dia de "hoy"" 
respectivamente (Segun el titulo). Si tuvieramos que traducirlas, 
probablemente seria algo asi: 

■ DATESYTD: Fechas del ano hasta hoy 

■ DATESMTD: Fechas del mes hasta hoy 

■ DATESOTD: Fechas del Trimestre hasta hoy 

Vemos la sintaxis y argumentos primeramente de la funcion 
DATESYTD. 


DATESYTD(<Fecha>; <Fecha_Fin_Ano>) 


Sintaxis 


Argumentos 

Ar gumento Description 

Fecha Una Columna que contenga fechas. 

Fecha_Fin_Ano Optional. Una cadena de caracteres que 
senale la ultima fecha del ano. 


Argumentos de la Funcion DATESYTD 


Observemos un ejemplo directamente para que nos ayude a 
visualizar como labora esta funcion. 


TABLA_Pedidos[lngreso del ANOS HASTA HOY]:= 
CALCULATE([lngresos];DATESYTD(Calendario[Fecha])) 
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Creemos una tabla dinamica con la siguiente configuracion: el 
campo Mes nombre de la tabla Catendario al area de filas, la medida 
Ingresos e Ingresos del ANOS HAST A HOY al area de valores, el campo 
Ano de la tabla calendario al area de filtros, y en el seleccionamos 
el elemento 2014 . 


Ano 


Etiquetas de fila 


Enero 

Febrero 

Narzo 

Abril 

Mayo 

Junio 

Julio 

Agosto 


2014 


Ingresos 




Ingreso del ANOS HASTA HOY Fiscal 


$20,876.35 

$21,311.08 

$20,357.40 

$22,518.44 

$21,130.56 

$20,221.34 

$24,114.66 

$23,762.44 


130429.97 

151741.05 

172098.45 
194616.89 

215747.45 
235968,80 

24114.66 

47877.10 


Septiembre 

$20,755.65 


68632.75 

Octobre 

$22,705.33 


91338.08 

Novieimbre 

$19,365.00 


1 10703.08 

Diciermbre 

$19,573.94 


130277.01 

Total general 

$256,692.19 


130277.01 

1 Reo 10.10 a 12 IQ ... (+) 

a 

_i 


B 


B 


Promedio: t21 p 7S6.53 Recuento: S Suma: S174 P 292.2S 


Figura 10.12 - Tablo Dinamica para ejemplificar DATESYTD 


Consideraciones Criticas 

CALCULATE Debemos enmarcar con negrita, que para la creacion de la medida 

Ingresos del aho HASTA HOY, se utilizo la funcion CACULATE debido 
a que DATESYTD retorna una tabla, esta es el filter context alterado 
hasta la primera fecha del ano, por lo cual debemos resumir esos 
datos en un solo valor, es alii donde entra CALCULATE mediante su 
primer argumento podemos definir la expresion con la cual 
deseamos resumir los datos, mientras que en su segundo ... 
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Argumento definimos de que manera queremos alterar el filter 
context alii es donde ejecuta su rol DATESYTD. 


Cuando entramos a mirar la funcion DATESYTD, podemos observar 
que en su argumento fecha, el cual es comun a practicamente 
todas las funciones Time Intelligence, indicamos 
Calendario[Fecha], es decir, para los argumentos fecha se debe 
poner la Primary key, la columna del primer requisito para la tabla 
de calendario. 


Argumento 
Comun en Time 
Intelligence 


jToma Nota! 



Somos conscientes que, en la tabla Pedidos, tenemos compos como: 
Ano, Mes, Mes Numero, etc. Similares a los que construlmos en la 
tabla de calendario, la verdad es que debemos evitar a toda costa 
utilizar los de la tabla pedldo o cualquier tabla matriz en general, 
debemos acostumbrarnos a hacer uso siempre de los compos en la 
tabla de calendario. En el Capttulo 12 dilucidamos porque. 


Retomando la funcion DATESYTD, en la tabla 10.3, que presenta sus 
argumentos, podemos fijarnos que tiene un segundo argumento 
opcional, este corresponde a la fecha que queremos que se tome 
como final de afio, que por defecto es "31/12". El argumento 
fln_de_ano es clave, porque lo podemos utilizar para indicar el ano 
fiscal o financiero, este varia dependiendo del pais y para alguno 
de ellos es "30/06". 


Argumento 

Opcional 

DATESYTD 


TABLA_Pedidos[lngreso del ANOS HASTA HOY Fiscal]- 
CALCULATE([lngresos];DATESYTD(Calendario[Fecha];"06/30")) 
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La funcion DATESMTD es exactamente igual que DATESYTD con La 
diferencia que no se devueLve hasta la primera fecha del ano, sino 
hasta la primera fecha del mes, veamos un ejemplo: 

[Ingresos MES HASTA HOY]= 
CALCULATE([lngresos];DATESMTD(Calendario[Fecha])) 


Ano 


2014 g 


NOTA 

En el ejemplo para la 
funcion DATEMYD 

utilizamos los meses y los 
subdivide por los distintos 
dfas, un escenario 
interesante es hacer lo 
mismo, pero con 
semanas, asf podremos 
analizar el 

comportamiento semana 
tras semana de, ingresos, 
costos, lo que 
necesitemos. Lo unico que 
debemos hacer es crear 
una columna que 
contenga las semanas y 
las puedas usar en 
cualquier reporte de 
tablas dinamica que 
derive de alii. 


Etiquetas de fila ,r Ingresos Ingresos MES HASTA HOY 


EBEnero 

$20,876.35 

$20,876.35 

- Febrero 

$21,31 1.08 

$21,31 1.08 

1/2/2014 

$ 1,334.94 

$1,334.94 

2/2/2014 

$ 1,282.67 

$2,617.60 

3/2/2014 

$953.00 

$3,570.60 

4/2/2014 

$839.41 

$4,410.01 

5/2/2014 

$472.91 

$4,882.92 

6/2/2014 

$288.36 

$5,171.28 

7/2/2014 

$291.59 

$5,462.87 

8/2/2014 

$388.13 

$5,851.00 

9/2/2014 

$179.09 

$6,030.08 

10/2/2014 

$ 1 ,619.28 

$7,649.37 

El Marzo 

$20,357.40 

$20,357.40 

E Abril 

$22,518.44 

$22,518.44 

BMayo 

$21,130.56 

$2 U 30.56 

1+1 li min 

tin in 

tin in 


Figura 10.13 - Ejemplificacion Medida con DATESMTD 


Y adivina que, DATESOTD es exactamente los mismo, pero con 
trimestres. 


Un aspecto a resaltar de las funciones DATESMTD y DATESOTD 
respecto a DATESYTD es que las dos primeras no tienen el 
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TOTALYTD, TOTLAMTD & TOTALOTD 

Estos tres chicos (TOTALYTD, TOTALMTD & TOTALOTD) son una 
evolucion de Las tres funciones anteriores para resumir Los datos 
que retornan de una vez, visto de una manera diferente, son un 
reempLazo para no utiLizar CALCULATE en Las tres funciones 
anteriores. Veamos sus equivaLencias: 

■ DATESYTD 

TABLA_Pedidos[lngreso deL ANOS HASTA HOY]:= 
CALCULATE([lngresos];DATESYTD(Calendario[Fecha])) 


■ TOTALYTD 

[Ingreso deL ANOS HASTA HOY (Con TOTALYTD)]:= 
TOTALYTD([lngresos];CaLendario[Fecha]) 


Ano 2014 |^r| 


Etiquetas de 

fila Q Ingresos 1 

igresos 

de ANO HASTA LA FECHA Ingreso 

del ANOS HASTA HOY (Con TOTALYTD) 

Enero 

$20,876,35 

f 

$20,876.35 

$20,876.35 

Febrero 

$21,311-08 


$42,187.43 

$42,187.43 

Marzo 

$20,357.40 


$62,544.83 

$62,544.83 

Abril 

$22,518.44 


$85,063.27 

$85,063.27 

Mayo 

$21,130.56 


$ 106,193.83 

$ 106,193.83 

Junio 

$20,221.34 


$126,415.18 

$ 126,415. IS 

Julio 

$24,114.66 


$ 150,529.84 

$ 150,529.84 

Agosto 

$23,762.44 


$ 174,292.28 

$ 174,292.28 


(tTCi 7« 


(t idt; r\A7 cal 

*t IQR OA 7 Cal 




Figura 10.14 - DATESYTD junto o TOTALYTD 
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Funcion 

TOTALYSTD 


Sintaxis 


A Resaltar 



Despues de haber visto la utilidad de la funcion TOTALYTD, 
aterricemos su definicion, sintaxis y argumentos. 

La funcion TOTALYTD evalua una expresion, como 
DISTINCTCOUNT(TABLA_Pedidos[Precio de Venta]) o una medida 
como [Ingresos], teniendo como objetivo adicional alterar el filter 
context de tal manera que calcule desde la primera fecha del ano 
hasta la actual. 

TOTALYSTD( <expresion>;<fecha>;[<filtro>];[<fin_de_ano>]) 



Argumentos de la funcion TOTALYSTD 


Argumento 

Description 

Expresion 

Una expresion que retorne un escalar. 

Fecha 

Una columna que contenga las fechas. 

Filtro 

Opcional. Una alteracion para el contexto. 

Fin_de_aho 

Opcional. Ultima fecha de ano. 


El argumento Filtro se comporta como los argumentos Filtros de 
CALCULATE, por lo que si lo deseamos podemos crear una medida 
algo asi: 


[Ingreso del ANOS HASTA HOY (Con TOTALYTD Chile)]:= 
TOTALYTD( [Ingresos]; 

Calendario[Fecha]; 

TABLA_Pedidos'[Pais]="Chile") 
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Adicionalmente, podemos ver que tenemos el argumento fin de 
ano, con lo cual podemos hacer calculos para anos fiscales. 

Las funciones TOTALMTD y TOTALOTD son los equivalentes para 
DATESMTD y DATESOTD, la diferencia es que no cuentan con 
ultimo argumento "Fin_de_Ano". 

CLOSINGBALANCEYEAR, CLOSINGBALANCEMONTH & 
CLOSINGBALANCEOUARTER 

Estos tres "motorratones" devuelve el valor de la expresion 
evaluado para el ultimo dia del ano, mes o trimestre dependiendo 
del caso, un ejemplo para clarificarlas: 


TABLA_Pedidos[Balance de Cierre del Ano] 
CLOSINGBALANCEYEAR([lngresos];Calendario[Fecha]) 



Figura 10.15 - Ejemplo pom CLOSINGBALANCEYEAR 
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Funcion 

CLOSNGBALANCEYEAR 

Sintaxis 



Las funciones CLOSINGBALANCEMONTH y 

CLOSINGBALANCEOUARTER, tienen el mismo comportamiento 
solamente que evaluan la expresion para el ultimo dia del mes y 
del trimestre en el contexto actual respectivamente. 

La funcion CLOSINGBALANCEYEAR evalua una expresion para la 
ultima fecha del ano en el contexto actual. 

CLOSINGBALANCEYEAR( 

<expresion>;<fecha>;[<filtro>];[<fin_de_ano>] ) 



Arguments funcion CLOSINGBALANCEYEAR 


Argumento 

Description 

Expresion 

Una expresion que retorne un escalar. 

Fecha 

Una columna que contenga las fechas. 

Filtro 

Opcional. Una alteracion para el contexto. 

Fin_de_aho 

Opcional. Ultima fecha del ano. 


Observemos que tenemos argumentos similares a la familia 
anterior, y por supuesto, se comportan de la misma manera; con el 
argumento filtro podemos alterar el contexto, mientras que con el 
parametro fin_de_ano podemos establecer cual es el ultimo dia del 
ano, como mencionamos anteriormente, para trabajar con afios 
fiscales. 

Igualmente, las funciones para mes y trimestre carecen del ultimo 
argumento, podemos notar como este parametro se repite en las 
distintas familias. 
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OPENINGGBALANCEYEAR, OPENINGBALANCEMONTH & 
OPENINGALANCEOUARTER 

Habiendo visto La "familia" de funciones "CLOSING" podemos 
inferir directamente que: esta familia tiene un comportamiento que 
devuelve el valor de La expresion evaluado para el primer dia de 
ano, mes o trimestre dependiendo del caso. Vamos al ejemplo: 


TABLA_Pedidos[Balance Inicio de Ano] 
OPENINGBALANCEYEAR([lngresos];Calendario[Fecha]) 


Ano 20 14 [t] 


Etiquetas de fila Q Ingresos Balance de Cierre del Ano Balance Inicio de Ano 


- 

1/1/2014 

2/1/2014 

3/1/2014 

4/1/2014 



Total general $256,692.19 $673.41 $287.97 

Figura 10.16 - Visuolizando lafuncion OPENINGBALANCEYEAR 


$770.92 

$673.41 

$237.97 

$709.36 

$673.41 

$287.97* 

$425.76 

$673.41 

$287.97 

$301.66 

$673.41 

$287.97 


Los argumentos son exactamente iguales a las dos familias 
anteriores. 
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Funcion 

DATESBETWEEN 


Sintaxis 



DATESBETWEEN 

Una familia con un solo integrante, pero muy querida ya que nos 
proporciona la posibilidad de crear tablas en intervalos de fechas 
determinados, veamos su definicion, sintaxis y argumentos. 

La funcion DATESBETWEEN, retorna una tabla compuesta por una 
columna de fechas que empieza en una fecha inicial indicada en el 
segundo argumento y una final senalada en el tercer argumento. 

DATESBETWEEN( <fechas>;<inicial>;<final>) 



Argumentos de la Funcion DATESBETWEEN 

Argumento 

Descripci on 

Fecha 

Una columna que contenga las fechas. 

Inicial 

Expresion que devuelva una fecha 

Final 

Expresion que devuelva una fecha 


jToma Nota! 

Ftjate como los dos ultimos argumentos indican expresiones que 
retornen una fecha. Si queremos colocar una fecha fija, por ejemplo, 
01/04/2000, entonces lo debemos hacer mediante una de las 
funciones clasicas de fechayhora: DATE, asi: DATE(2000;4;1). Aunque 
en los argumentos se puede indicar como: “1/4/2000", evita esta 
forma ya que puede retornar valores inesperados e incorrectos. 


Realicemos una sencilla tabla dinamica donde veamos los ingresos 
generados entre las fechas 01/04/2000 y 01/10/2000. 
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[Ingresos 2015 (6 Meses Representativos)]:= 
CALCULATE! [Ingresos]; 

DATESBETWEEN(Calendario[Fecha]; 

DATE(2000;4;01); 

DATE(2000;10;01)) 

) 


Con La medida anterior podemos llevar eL campo categoria al area 
de filas y asi ver Los ingresos representatives. 


1 Etiquetas de fib Q Ingresos 2015 (6 Meses 

Representatives) jj 

Blue-Ray 

$4,180 

CD 

$2,748 

Combo 

$62,210 

Libro 

$18,744 

Total general 

$87,883 


Figura 10. 17-Toblo Dinomico con Medida que utiliza DATES BETWEEN 


LASTDATE & FIRSTDATE 

Esta familia La podemos tomar como Los equivaLentes de MAX y MIN 
para campos de tipo fecha, La funcion LASTDATE retorna La ultima 
fecha en un campo especificado, mientras que FIRSTDATE retorna 
la primera fecha del campo (Primer dia de operaciones). Ambas 
funciones solamente cuentan con un argumento y este es la 
columna donde queremos hallar el "maximo" o el "minimo" en 
terminos de fecha. 
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Conociendo estas funciones podemos plantear un escenario 
interesante junto con DATESBETWEEN, consiste en evaluar una 
expresion desde el primer dia de operacion hasta la fecha presente 
en el contexto actual. 


[Ingresos (Vida de Operacion)]= 
CALCULATE( 

[Ingresos]; 

DATESBETWEEN ( 


Calendario[Fecha]; 

FIRSTDATE ( ALL ( Calendario[Fecha]) ); 
LASTDATE ( Calendario[Fecha]) 

) 


Tabla Dinamica: 


1 Etiquetas de fila Q Ingresos 

Ingresos (Vida de Operacion) 


Seleccionar c< 

1999 

$8,685.83 

$8,686 


[Buscar 

2000 

$180,680.24 

$189,366 


n fr 

2001 

$166,860.36 

$356,226 


l_l JX 

□ /* 

2002 

$184,876.83 

$541,103 


□ A 

2003 

$177,061.95 

$718,165 


□ A 

2004 

$168,059.37 

$886,225 


□ A 

2005 

$187,906.44 

$1,074,131 


□ A 

n 

2006 

$198,797.54 

$1,272,929 


U Jx 

0 A 

2007 

$170,712.79 

$1,443,641 


2008 

$175,936.37 

$1,619,578 


Arrastrar can 

2009 

$198,222.01' 

$1,817,800 


T FILTROS 

2010 

$240,873.82 

$2,058,674 



2011 

$216,088.04 

$2,274,762 



2012 

$229,644.13 

$2,504,406 



2013 

$232,463.65 

$2,736,869 



2014 

$256,692.19 

$2,993,562 


= FILAS 

2015 

$327,323.99 

$3,320,886 


| Ano 

Total general 

$3,320,885.54 

$3,320,886 



| ■■■ © 

i rn i h 

O Aplazarai 


Figura 10.18 - Tabla Dinamica con Medida Vida de Operacion 
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DATEADD & SAMESPERIODLASTYEAR 


La funcion DATESADD retorna una tabla que contiene una columna 
con fechas desfasadas hacia adelante o hacia atras en eltiempo de 
acuerdo a Las fechas en el contexto actual. 


DATEADD(<Fecha>;<num_ desfase;<tipo>) 


Definicion 

DATEADD 


Sintaxis 



Argumentos de la funcion DATESADD 


Argumentos 


Argumento 

Description 

Fecha 

Una columna que contenga las fechas. 

Num_Desfase 

Un valor entero que indique que se debe 
desfasar hacia adelante o atras. 

Tipo 

En terminos de que esta el desfase: Anos, 
Trimestre, Mes o Dias. 


Conociendo esta funcion podemos crear la tasa de crecimiento 
basica, la cual compare el aho actual con el aho previo, a diferencia 
de la tasa de crecimiento basica que creamos en el capitulo 8 aho 
que toma un aho base. 


iComo identificamos los ingresos de aho previo? 


[Ingresos Aho Previo]:= 

CALCULATE! [Ingresos]; 

DATEADD(Calendario[Fecha];-l;YEAR) 

) 
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TABLA_Pedidos[Tasa de Crecimiento (Ano a Ano)]:= 
DIVIDE([lngresos]-[lngresos Ano Previo];[lngresos Ano Previo]) 


Campo Ano de la tabla 
Calendario. 


NOTA 

Ten en cuenta que la 
medida Tasa Basica 
Crecimiento creada en el 
capitulo 8 si se utiliza en 
esta tabla dinamica arroja 
valores erroneos, en 
esencia, porque esta 
haciendo los filtros 
respecto a las fechas en la 
tabla pedidos. 


Etiquetas de fila T Ingresos Ingresos Ano Previo Tasa de Crecimiento (Ano a Ano) 


1999 

$8,685.83 


f 

\ 

2000 

$180,680.24 

$8,686 


1980.172% 

2001 

$166,860.36 

$180,680 


-7.649 % 

2002 

$184,876.83 

$ 166,860 


10.797% 

2003 

$177,061.95 

$184,877 


-4.227% 

2004 

$ 168,059.37 

$ 177,062 


-5.084 % 

2005 

$187,906.44 

$168,059 


1 1.810% 

2006 

$198,797.54 

$187,906 


5.796% 

2007 

$170,712.79 

$198,798 


-14.127% 

2008 

$175,936,37 

$170,713 


3.060 % 

2009 

$198,222.01 

$175,936 


12.667% 

2010 

$240,873.82 

$198,222 


21.517% 

2011 

$216,088.04 

$240,874 


-10.290% 

2012 

$229,644.13 

$216,088 


6.273 % 

2013 

$232,463.65 

$229,644 


1.228% 

2014 

$256,692.19 

$232,464 


10.423 % 

2015 

$327,323.99 

$256,692 


27.516% j 


Figura 10.19- Tabla Dinamica con DATESADD, Tasa de Crecimiento (Ano a Ano) 


SAMEPERIOD Esta es una vers '° n especifica de la funcion DATESADD, ya que 

LASTYEAR desfasa las fechas en el contexto actual un ano previo. La medida 

Ingresos Ano previo puede ser escrita: 

[Ingresos Ano Previo]:= 

CALCULATED ngresos]; 
SAMEPERIODLASTYEAR(Calendario[Fecha])) 

STARTOFMONTH, STARTOFOUARTER & STARTOFYEAR 



Estas funciones las podemos traducir, asi 
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■ STARTOFMONTH: Primera fecha del mes en el contexto 
actual 

■ STARTOFOUARTER: Primera fecha del trimestre en el 
contexto actual 

■ STARTOFYEAR: Primera fecha del afio en el contexto actual 


Estas tres funciones solamente necesitan un argumento, y este es 
el campo de fecha con las fechas consecutivas en nuestra tabla de 
calendario. 


ENDOFMONTH, ENDOFOUARTER & ENDOFYEAR 

Nada extraho con este grupo, similares a las anteriores solo que 
devuelven la ultima fecha. Una imagen para ilustrar: 


Etiquetas de fila 

Fecha Inicio Mes 

Fecha Incio Trimestre 

Fecha de Incio de Ano 

Fecha Fin Mes 

Fecha Fin Trimestre 

Fecha fin Ano 

EB 1999 

14/12/1999 00:00 

14/12/1999 00:00 

14/12/1999 00:00 

31/12/1999 00:00 

31/12/1999 00:00 

31/12/1999 00:00 

9- 2000 

1/1/2000 00:00 

1/1/2000 00:00 

1/1/2000 00:00 

31/12/2000 00:00 

31/12/2000 00:00 

31/12/2000 00:00 

at 2001 

1/1/2001 00:00 

1/1/2001 00:00 

1/1/2001 00:00 

31/12/2001 00:00 

31/12/2001 00:00 

31/12/2001 00:00 

E 2002 

1/1/2002 00:00 

1/1/2002 00:00 

1/1/2002 00:00 

31/12/2002 00:00 

31/12/2002 00:00 

31/12/2002 00:00 

91 

1/1/2002 00:00 

1/1/2002 00:00 

1/1/2002 00:00 

31/3/2002 00:00 

31/3/2002 00:00 

31/12/2002 00:00 

Enero 

1/1/2002 00:00 

1/1/2002 00:00 

1/1/2002 00:00 

31/1/2002 00:00 

31/3/2002 00:00 

31/12/2002 00:00 

Febrero 

1/2/2002 00:00 

1/1/2002 00:00 

1/1/2002 00:00 

28/2/2002 00:00 

31/3/2002 00:00 

31/12/2002 00:00 

Marzo 

1/3/2002 00:00 

1/1/2002 00:00 1 

1/1/2002 00:00 

31/3/2002 00:00 

31/3/2002 00:00 

31/12/2002 00:00 

02 

1/4/2002 00:00 

1/4/2002 00:00 

1/1/2002 00:00 

30/6/2002 00:00 

30/6/2002 00:00 

31/12/2002 00:00 

Abril 

1/4/2002 00:00 

1/4/2002 00:00 

1/1/2002 00:00 

30/4/2002 00:00 

30/6/2002 00:00 

31/12/2002 00:00 

Junio 

1/6/2002 00:00 

1/4/2002 00:00 

1/1/2002 00:00 

30/6/2002 00:00 

30/6/2002 00:00 

31/12/2002 00:00 

Mayo 

1/5/2002 00:00 

1/4/2002 00:00 

1/1/2002 00:00 

31/5/2002 00:00 

30/6/2002 00:00 

31/12/2002 00:00 

03 

1/7/2002 00:00 

1/7/2002 00:00 

1/1/2002 00:00 

30/9/2002 00:00 

30/9/2002 00:00 

31/12/2002 00:00 

Agosto 

1/8/2002 00:00 

1/7/2002 00:00 

1/1/2002 00:00 

31/8/2002 00:00 

30/9/2002 00:00 

31/12/2002 00:00 

Julio 

1/7/2002 00:00 

1/7/2002 00:00 

1/1/2002 00:00 

31/7/2002 00:00 

30/9/2002 00:00 

31/12/2002 00:00 

Septiembre 

1/9/2002 00:00 

1/7/2002 00:00 

1/1/2002 00:00 

30/9/2002 00:00 

30/9/2002 00:00 

31/12/2002 00:00 

04 

1/10/2002 00:00 

1/10/2002 00:00 

1/1/2002 00:00 

31/12/2002 00:00 

31/12/2002 00:00 

31/12/2002 00:00 

Diciembre 

1/12/2002 00:00 

1/10/2002 00:00 

1/1/2002 00:00 

31/12/2002 00:00 

31/12/2002 00:00 

31/12/2002 00:00 

Noviembre 

I/I 1/2002 00:00 

1/10/2002 00:00 

1/1/2002 00:00 

30/11/2002 00:00 

31/12/2002 00:00 

31/12/2002 00:00 

Octubre 

1/10/2002 00:00 

1/10/2002 00:00 

1/1/2002 00:00 

31/10/2002 00:00 

31/12/2002 00:00 

31/12/2002 00:00 

ffl 2003 

1/1/2003 00:00 

1/1/2003 00:00 

1/1/2003 00:00 

31/12/2003 00:00 

31/12/2003 00:00 

31/12/2003 00:00 

( 4-1 

i it nnn4 nn-nn 

i /■ I'tnnA nn-nn 

■ it nt\i\A nn-nn 

■a i /i innn4 nn-nn 

a i it -i/'i tu\A nn-nn 

? i /1 mnn4 nn-nn 



Figura 10.20- Funciones STAR y END (MONTH, QUARTER y YEAR) 
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Tablas de Calendario Personalizado 

Los calendarios personalizados son un tipo de calendario 
importante, debido a que los calendarios estandar pueden tener 
varios inconvenientes para distintas empresas, algunos ejemplos: 

Comparar meses no siempre es adecuado, puede que el mes actual 
tenga mas dias que el mes anterior (31 dias y 30 dias) con lo cual 
hacer un analisis de crecimiento de ventas por este dia de 
diferencia no siempre sera una comparacion justa. 

Aunque tengan el mismo numero de dias los meses, varia el numero 
de domingos y dias feriados, por lo cual la comparacion tampoco 
seria justa. 

Es frecuente querer comparar periodos en el tiempo, una longitud 
de dias, meses o incluso anos. 


^Donde se Presentan Calendarios Personalizados? 

Para ser honestos, los calendarios personalizados son mas 
frecuentes que los estandares, por mencionar algunos: 

■ Temporadas Deportivas 

■ Programacion de Proveedores 

■ Semestres Academicos 

■ Calendarios de Minoristas. 


Ademas, estamos seguros que se te viene a la cabeza uno o dos 




ejemplos adicionales. 
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Las tablas de calendarios pueden estar configuradas como 
nosotros necesitemos, es decir, puede que Las coLumnas de fechas 
no tengan fechas consecutivas, que Las fechas correspondan a 
periodos o cicLos asignados en vez de meses. Por ejemplo, un 
caLendario universitario, Las primeras 5 semanas a partir de febrero 
pueden corresponder a la categoria primer tercio, luego 4 semanas 
a segundo tercio y otras 5 semanas posteriores a tercer tercio. 

CALENDARIO PersonaLizado: 4-4-5 

Otro tipo en el ambito Laboral, es el caLendario personalizado 4-4- 
5, que es frecuente para algunas industrias de manufactura. El 
caLendario 4-4-5 divido un aho en 4 trimestres, donde cada uno 
esta compuesto por 13 semanas las cuales se agrupan en dos 
periodos de 4 semanas uno de 5 semanas, estos hacen las veces 
de los meses. 

A continuacion, presentamos este tipo de caLendario como tabla en 
Excel (Puedes encontrarlo en el compendio de archivos) 


Dfa del AnoQ Fecha Q Numero Dfa 

SemanaQ Nombre Abreviado D 

a □ Nombre Dfa de la Semana Q Dfa del Mes 

Q ;Fin de Semana? Q Semana del Ano NumQ Sen] 

1 

1/1/1999 

6 sab. 

sabado 

1 N 

1 

2 

2/1/1999 

7 dom. 

domingo 

2 Y 

1 

3 

3/1/1999 

1 lun. 

lunes 

3 Y 

1 

4 

4/1/1999 

2 mar. 

martes 

4 N 

1 

5 

5/1/1999 

3 mie. 

miercoles 

5 N 

1 

6 

6/1/1999 

4 jue. 

jueves 

6 N 

1 

7 

7/1/1999 

5 vie. 

viernes 

7 N 

1 

8 

8/1/1999 

6 sab. 

sabado 

8 N 

2 

9 

9/1/1999 

7 dom. 

domingo 

9 Y 

2 

10 

10/1/1999 

1 lun. 

lunes 

I0Y 

2 

II 

11/1/1999 

2 mar. 

martes 

II N 

2 

12 

12/1/1999 

3 mie. 

miercoles 

12 N 

2 

13 

13/1/1999 

4 jue. 

jueves 

13 N 

2 

14 

14/1 / 1999 

5 vie. 

viernes 

14 N 

2 

15 

15/1 /1999 

6 sab. 

sabado 

15 N 

3 

16 

16/1 /1999 

7 dom. 

domingo 

16 Y 

3 

17 

17/1/1999 

1 lun. 

lunes 

17 Y 

3 

18 

18/1/1999 

2 mar. 

martes 

18 N 

3 

19 

19/1/1999 

3 mie. 

miercoles 

19 N 

3 


Figura 10.21- To bio de CaLendario Personalizado 4 - 4-5 
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Para las tablas de calendario personalizado se deben crear las 
funciones time Intelligence de manera personalizada con las 
funciones que se han estudiado hasta este punto. 

TOTALYTD Para Calendarios Personalizados 

Por ejemplo, la siguiente formula emula TOTALYSTD: 


[TOTALY5TD Personalizado]= 

CALCULATE( 

[Ingresos]; 

FILTER ( 

ALL (Calendario ); 

CalendariofAfio] = MAX ( Calendario[Ano]) 
bb Calendario[Fecha] <= MAX ( Calendario[Fecha]) 

) 

) 


Si agregamos esta formula podemos ver que hace exactamente lo 
mismo: 


Etiquetas de fila Q TOTALYSTD Personalizado 


Abril 

Agosto 

Diciembre 

Enero 

Febrero 

Julio 

Junio 

Marzo 

Mayo 

Noviembre 

Octubre 

Septiembre 


$69,793.95 
$150,502.86 
$229,644.13 
$17,316.83 
$32,781.16 
$131,840.43 
$114,579.93 
$53,491.26 
$92,605.80 
$209,633.56 
$191,667.26 
$170,975.94 


Ano 

2008 

2009 

2010 
2011 
2012 

2013 

2014 

2015 


Total general 


$229,644.13 


Figura 10.22 -TOTALYSTD Personalizado 
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La diferencia es que estas formulas nos sirven para tablas de 
calendario personalizado. 



Pausemos un Momento 

Esta tematica es muy buena, para que construyas tus propias 
formulas y columnas calculadas en la tabla de calendario de acuerdo 
a tus necesidades, y explotes tu creatlvidad para lograr los objetivos. 
Si utilizas tablas de calendario personalizado en tu trabajo, es ideal 
que experimentes e interiorices el lenguaje DAX con funciones Time 
Intelligence Personalizadas. 


El Siguiente Paso 

En el capitulo numero once, descubriras como recibir valores de 
entrada del usuario que incidan de forma inmediata en reporte de 
tabla dinamica, esto mediante una implementacion especial de 
tablas en el modelo de datos, con lo cual podemos crear lo que se 
denomina: reporte parametrizable. tQue tal suena? Continua 
leyendo para que entiendas de que estamos hablando. 







La Presente Pagina se ha dejado en Blanco de forma deliberada. 




CapituLo 11 


Tablas Slicer: Datos de Entrada del 

Usuario 





Capitulo 11 / Tablas Sheer: Datos de Entrada del Usuario 



Reporte, 

Usuario 


Suministrar 
Parametros 
con Slicer 


Reportes Parametrizables 

Primero, debemos recordar que las tablas dinamicas tienen un serio 
problema para trabajar en equipo con el usuario final en terminos 
de analisis de escenarios, debido a que no es posible establecer 
una comunicacion: Reporte - Usuario, en otras palabras, las tablas 
dinamicas NO cuentan con la habilidad de recibir parametros y en 
consecuencia modificar sus calculos para obtener otra perspectiva 
de la situacion analizada. Si quisieras suministrar algun parametro 
al reporte, tendrias que alterar su estructura agregando o 
modificando campos, algo que resulta poco intuitivo y nada 
amigable, una situacion que afecta directamente en la 
productividad; sin embargo, para cambiar este crudo panorama 
contamos con las Tablas Slicer, elemento que es posible crear, 
gracias al inmenso poder de Power Pivot... 

<-Oue es un Reporte parametrizable? 

Es un tipo de reporte que permite al usuario suministrar parametros 
a una tabla dinamica a traves de un Slicer, para asi, obtener 
conclusiones en diferentes escenarios, su funcionalidad es posible 
gracias al lenguaje DAX, mas adelante comprenderas como las 
Expresiones DAX entienden el parametro, y posteriormente, 
obtienen los calculos correspondientes. 


Tabla Slicer 


Es un Slicer que contiene los diferentes parametros a aplicar en el 
reporte y que, a su vez, ha sido creado a partir de una tabla agregada 
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al modelo de datos pero que NO ha sido relacionada con ninguna 
otra dentro del modelo, si, aunque no lo creas, la tabla para crear 
el Sheer con los diferentes parametros, no debe estar conectada, lo 
sabemos jPobre Tabla!, debe estar muy triste aislada y sola, no 
obstante, su proposito dentro del modelo es muy importante, pero 
entendamos que papel juega a traves de un ejemplo. 

Lineamientos para Construir Reporte Parametrizado 

Imaginemos que hemos creado una tabla dinamica a partir de la 
Tabla_Pedidos, que muestra la utilidad obtenida en los diferentes 
paises, sin embargo, para completar el reporte vamos a estimar la 
utilidad neta despues de impuestos, teniendo en cuenta que la tasa 
varia en cada pais y, en consecuencia, debe ser flexible para que el 
usuario final pueda elegir entre diferentes tasas, jManos a la Obra! 


Pais 

Q Utilidad ($) 

Argentina 

339.659 

Brasil 

321.821 

Chile 

308.522 

Colombia 

332.051 

Ecuador 

332.623 

Paraguay 

334.109 

Peru 

333.343 

Uruguay 

313.965 

Venezuela 

340.161 


Total general 2.956.254 

Figura 11.1 - Tabla de Utilidad Antes de Impuestos 


NOTA 

Las Tablas Slicer tambien 
son conocidas en el 
mundo de Power Pivot 
como Tablas de 
Parametros. 


NOTA 

Hasta el momenta no 
tenemos una medida 
explfcita para la utilidad, a 
pesar de que tenemos la 
utilidad creada como 
Columna Calculada, 
recuerda que es mejor 
tenerla como media ya 
que ayuda a tener un 
modelo de datos 
optimizado en su 
rendimiento. 


Tabla_Pedidos[Utilidad ($)] := 

SUM ( TABLA_Pedidos[Precio de Venta]) - SUM ( TABLA_Pedidos[Costo de Envio]) 

- SUM (TABLA_Pedidos[Costo del Producto]) - SUM (TABLA_Pedidos[Costo Empaque]) 
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CrearTabla de 
Para metros 


NOTA 

Las tablas que se utilizaran 
como parametros (Tablas 
Slicer) no son la excepcion 
a las buenas practicas que 
hemos mencionado 
anteriormente, en 

particular, se le debe 
asignar un nombre 
descriptivo y apropiado 
antes de anadirla a Power 
Pivot. 


Pues bien, lo primero que vamos a hacer es crear una Tabla 
Estructurada con las diferentes tasas de impuesto, para luego 
agregarla al modelo de datos. 



La tabla estructurada debe ser creada en una hoja que no contenga 
mas tablas dentro de si, puesto que debemos restringir el acceso 
por parte del usuario final, pero mas adelante hablaremos de ello, 
ahora, lo que nos interesa es agregar la tabla al modelo de datos; 
dejando la celda activa dentro de la Tabla, nos dirigimos a la 
Pestana POWER PIVOT y en el grupo TABLAS, elegimos el Comando 
AGREGAR A MODELO DE DATOS. 




Agregar a ^ctualizar 
modelo de datos todo 


Tablas 


Figura 11.3- Comando Agregar al Modelo de Datos 


Cuando trabajamos con tablas desconectadas, es buena practica 
organizarlas en la vista de diagrama, de tal forma que queden 
aisladas en la parte derecha, en la siguiente figura se ilustra mejor 
la situacion para repasar la metodologia: 


CrearTabla de 
Parametros 


NOTA 

Las tablas que se utilizaran 
como parametros (Tablas 
Slicer) no son la excepcion 
a las buenas practicas que 
hemos mencionado 
anteriormente, en 

particular, se le debe 
asignar un nombre 
descriptivo y apropiado 
antes de anadirla a Power 
Pivot. 
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Tablas de Busqueda, situadas en la 
parte superior de la vista de diagrama 

-T- 


ED sku 
ED Categoria 
ED Precio de Venta 


ED Fecha 
ED Ario 

ED MesNumero 
ED Mes Nombre 
fTTI Mps Dip 


11 


ED Descuento(%) 

ED Categoria de Descue... 


□ Numero de Pedido 
ED Tipo de Compra 

□ SKU 

ED Categoria de Descuento 
ED Precio de Venta 
(D Unidades 

□ Costo del Producto 


Tabla Matriz o Base. 


ED sku 

ED Producto(s) 

ED Suma Agregada Ing... 
ED Suma Agregada Ing... 

n Columns rain i laris 1 



Tabla 

Desconectada, 
aislada dentro 
de la vista de 
diagrama 


Figura 11. 4-Aislar Tobias Desconectada 


Ubicar Las tabLas con esta configuracion ayuda a que el 
entendimiento del modelo sea intuitivo y facil para cualquier 
usuario. Por ultimo, agregamos un slicer con el campo de la tabla 
desconectada (Impuesto %). 


Impuesto (%) 



* 

0,15 

0,16 

0,17 

0,18 

0,19 

0,2 



1 Pais Q Utilidad ($) 1 

Argentina 

339.659 

Brasil 

321.821 

Chile 

308.522 

Colombia 

332.051 

Ecuador 

332.623 

Paraguay 

334.109 

Peru 

333.343 

Uruguay 

313.965 

Venezuela 

340.161 


Total general 2.956.254 


NOTA 

La ilustracion de la vista de 
diagrama de este capftulo 
se presente en la interfaz 
de Excel 2013, situacion 
que es una variante 
respecto al resto de 
capftulos donde todo se 
ilustra en Excel 2016. 


Figura 11. 5 - Insertor Slicer a portir de lo Tabla Desconectada 
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/ Tablas Slicer: Datos de Entrada del Usuario 

Antes de construir la Medida que trabajara en equipo con el Slicer 

que contiene los parametros, debemos presentarte la funcion 

HASONEVALUE, asi que hablemos un poco sobre ella. 

Funcion 

HASONEVALUE 

La funcion HASONEVALUE, retorna TRUE si en la columna 

especificada solo existe un unico valor, en caso contrario (la 
columna contiene dos o mas valores diferentes), retorna FALSE. 

Sintaxis 

HASONEVALUE(<Columna>) 

Argumentos 

^ Argumentos Funcion HASONEVALUE 

Argumento Description 

Columna Nombre de una Columna Existente 

La funcion HASONEVALUE, solo cuenta con un unico argumento, 

Columna, el cual, es la columna en la que se identificara si tiene un 

unico valor o no, teniendo en cuenta que ya te hemos presentado 

esta funcion vamos a continuar con la construccion de nuestro 

reporte parametrizable. 

Recordemos que la Utilidad despues de impuestos es igual al 

Impuesto multiplicado por la diferencia entre 1 menos la tasa de 

impuesto, a continuacion, se muestra la formula: 

Utilidad Neta = (Utilidad Antes de lmpuestos)*(l- % de Impuesto) 


Bien, ha llegado el momento de la verdad, ya conocemos como se 
calcula la utilidad neta, en este momento, vamos a traducir la 
formula al lenguaje DAX, a continuacion, se muestra la medida. 
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lmpuesto[Utilidad Neta]= 

IF ( HASONEVALUE (lmpuesto[lmpuesto (%)] ); 
[Utilidad ($)] 

* (1 - MAX (lmpuesto[lmpuesto (%)]) ); 
BLANK () ) 


Esta funcion identifica si se ha elegido un solo parametro en el 
Slicer, de ser cierto calcula la utilidad neta, en caso de elegir mas 
de un parametro en el Slicer, la funcion NO calcula la utilidad, sino 
que muestra valores en bianco en la tabla dinamica. 


jToma Nota! 


O Aprovechamos para repasar un concepto fundamental, 
encapsulation: Siempre que trabajes con columnas dentro de una 
medida, debes encapsular dicha columna en una Funcion de 
Agregacidn, como puedes ver en la anterior expresion DAX, donde se 
utiliza MAX para encapsular la columna Impuesto en el segundo 
. arqumento de IF. 


Con Paises a filas y Utilidad Neta a valores, tenemos: 


Impuesto (%) 


0,15 

0,16 

0,17 

0,18 

0,19 

0,2 


Pais 

Q Utilidad ($) 

Utilidad Neta 1 

Argentina 

339.659^ 

288.71 o| 

Brasil 

321.82 li 

273.548 

Chile 

308.522) 

262.244 j 

Colombia 

332.05 1 

282.244 [ 

Ecuador 

332.623! 

282.729 

Paraguay 

334.109 

| 

283.993 

Peru 

333.343J 

283.341 j 

Uruguay 

313.965) 

266.871 j 

Venezuela 

340.161! 

289.l37j 

Total general 2.956,254 

2.512,816 


El Slicer de Impuesto ya no actua 
como uno normal, sino como una 
tabla que contiene ciertos 
parametros que permiten cambiar 
como se muestran los valores de 
cierta parte en la tabla dinamica, 
este caso Utilidad Neta 



Una vez se ha seleccionado un impuesto, 
esta columna lo refleja ya que en la 
medida asociado se esta tomando el 
valor de la tabla slicer para restarle el 
porcentaje escogido. 



Figura 11.6- Utilidod Neta de acuerdo al impuesto (%) seleccionado en el Slicer 
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NOTA 

Como las tablas Slicer no 
estan relacionadas con 
ninguna otra tabla por 
naturaleza, Excel mostrara 
el mensaje de deteccion y 
creacion de relaciones, 
esto puede ser un poco 
confuso, por lo cual 
desactivar la deteccion 
automatica no es mala 
idea. 


En este punto, si elegimos otro porcentaje, La columna utiLidad neta 
realizara Los calculos dependiendo del impuesto elegido, todo esto 
es posible gracias a las formula DAX que hemos creado, aunque, en 
el panel de campos de la tabla dinamica aparece un mensaje 
sugiriendonos que se necesita una relacion entre tablas, no debes 
asustarte, simplemente debes omitir este mensaje. 


Campos de tabla dinamica 

ACTIVO TODOS 

Seleccionar campos para agregar al informe: 


▼ X 



Puede que se necesite una relacion entre tablas. 


DETECCION AUTOMATICA... 


CREAR... 


X 


[Buscar 


P 


Figura 11. 7 - Sugerencia de Creation de relation 


Si seleccionamos mas de dos parametros, la tabla dinamica no 
muestra ningun valor, puesto que es ilogico calcular el impuesto 
con ambas tasas, esto se ha hecho intencionalmente y es posible 
gracias a La funcion BLANKQ, utilizada en la medida Utitidad Neta. 



Total general 2.956.254 


Figura 11.8- Election de Dos Parametros 
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Para finalizar La construccion de nuestro reporte, vamos a ocultar 
la hoja que contiene la tabla de Impuesto, podemos hacerlo de la 
manera clasica, dando clic derecho sobre la hoja y presionando la 
opcion Ocultar, aunque si prefieres ser mas precavido, puedes 
dirigirte a la pestana DESARROLLADOR, grupo CONTROLES, y alii 
das clic sobre el comando PROPIEDADES, y en este cuadro de 
dialogo debes configurar la opcion VISIBLE como 2 - 
xlSheetVeryHidden (Hoja de Excel Bien Oculta) 


Propiedades - Impuesto 


Impuesto Worksheet 


Alfabetica Por categonas 


(Name) 

Impuesto 

DisplayPageBreaks 

False 

DisplayRightToLeft 

False 

EnableAutoFilter 

False 

EnableCalculation 

True 

EnableFormatConditionsCL 

True 

EnableOutiining 

False 

EnablePivotTable 

False 

EnableSelection 

0 - xlNoRestrictions 

Name 

Tabla de Impuesto 

ScxollArea 


StandardWidth 


Visible 

2 - xlSheetVeryHidde ^ | 



Figura 11. 9 - Ventana de Propiedades 


Por este camino, la hoja queda oculta para que no se pueda mostrar 
desde la ventana de Excel, si deseas mostrar la hoja nuevamente, 
debes cambiar la propiedad a: xlSheetVisible en el editor de Visual 
Basic, con la tabla oculta, damos por finalizado la construccion de 
nuestro primer reporte parametrizable, para que te hagas una idea 
de la cantidad ilimitada de aplicaciones que tienen los reportes 
que reciben datos de entrada del usuario, vamos a recrear posibles 
escenarios en los pueden ser de ayuda. 

wm 


NOTA 


Tal vez no tengas la 
pestana 

DESARROLLADOR activa 
y, es posible que no 
conozcas muy bien el 
procedimiento para 
activar en la cinta de 
opciones. Si este es el caso 
te recomendaos el 
siguiente video basico 



Pestana Desarrollador v 

Sus Grupos 

Puedes estar interesado 
en un curso a partir de 
cero sobre macros hasta 
un nivel intermedio, por 
este te dejamos el enlace 
a la serie decida a Macros 
en nuestro canal de 
YouTube: 



Serie Dedicada a Macros 

en Excel 























Capitulo 11 / Tablas Sheer: Datos de Entrada del Usuario 


Escenarios con Tablas Slicers 

Escenario 1: Cambio de Unidades 

Para facilitar la lectura del reporte podemos crear una Slicer que 
permita cambiar la escala de las unidades presentadas en la tabla 
dinamica, para ello, en una nueva hoja vamos a crear una tabla con 
las diferentes escalas que queremos sean visualizadas, para 
posteriormente agregarla al modelo de datos y NO relacionarla con 
ninguna otra tabla: 



Figura 11.10- Tobla de Unidades 

Con la tabla agregada en el modelo de datos, vamos a crear una 
medida que nos permita cambiar las unidades de todo el reporte, 
para llevar a cabo esta accion solo debemos dividir cada valor del 
reporte, sobre la escala elegida: 

Unidades en Reporte = Valor en la Tabla / Escala elegida 

Teniendo en cuenta la ecuacion para el cambio de escala, vamos a 
crear nuestra medida en el lenguaje DAX: 

Escala[Cambio de Escala]:= 


IF ( HASONEVALUE ( Escala[Escala] ); 
[Utilidad ($)]/ MAX ( Escala[Escala]); 
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Ahora, agregamos esta medida al area de valores de la tabla 
dinamica, por cierto, no puedes olvidar crear el slicer de 
parametros a partir de la tabla desconectada (Tabla de Escala) que 
hemos agregado al modelo de datos. 


Escala 


T x 

1 

1000 

1000000 



| Pais Q Utilidad ($) Cambio de Escala 1 

Argentina 

339.659 

339,7 

Brasil 

321.821 

321,8 

Chile 

308.522 

308,5 

Colombia 

332.051 

332,1 

Ecuador 

332.623 

332,6 

Paraguay 

334.109 

334,1 

Peru 

333.343 

333,3 

Uruguay 

313.965 

314,0 

Venezuela 

340.161 

340,2 

Total general 

2,956.254 

2,956,5 


Figura 11 . 11 - Combio der Escala 


Como podras imaginar, la columna Cambio de Escala, muestra la 
utilidad dependiendo de las unidades seleccionadas en el Slicer, 
ademas, al igual que en el primer ejemplo, si elegimos mas de un 
parametro, la columna no mostrara ningun valor, recuerda que las 
posibilidades son infinitas y si bien este ejemplo parece sencillo, 
podemos extender la aplicacion de las Tablas Slicer a cualquier 
escenario. 

Escenario 2: Umbrales 


Con las tablas slicers tambien podemos darle la posibilidad al 
usuario de manipular rangos, por eso, observa el siguiente 
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Numero de unidades adquiridas, para asi determinar que tipo de 
cliente es el que genera mas ingresos, para ello, creamos una tabla 
con los rangos, posteriormente la agregamos al modelo de datos. 


NOTA 



Calculate y Filter son un 
duo que se presenta con 
frecuencia, puesto que 
Calculate solo permite 
hacer comparaciones en 
su argumento <Filter> 
con valores fjjos, por 
ejemplo: < Columna > = 
<Valor Fijo>. Si quieres 
hacer algo mas complejo 
como < Columna A> < = 
< Columna B>, debes 
incluir en dicho 
argumento la funcion 
FILTER () 


Figura 11.12- Tabla de Rangos 


En la tabla se muestran los diferentes rangos de cantidad de 
unidades adquiridas del mismo producto por cada persona, ahora, 
para hacer el calculo vamos a crear la siguiente medida, para que, 
dependiendo el umbral seleccionado, los calculos se modifiquen: 

Rango[Utilidad - Rango] := 

CALCULATE ([Utilidad ($)]; 

FILTER (TABLA_Pedidos; 

TABLA_Pedidos[Unidades] >= MAX ( Rango[Menor]) 
&&■ TABLA_Pedidos[Unidades] < MAX ( Rango[Mayor]) 

)) 



Pausemos un Momento 

Una variation de los umbrales que llega con la utilization de fechas, 
imagina por ejemplo que queremos ver desde el initio del mes hasta 
algun momento determinado o hasta el final, en dicho caso tambien 
es valido y con lo ayuda de las funciones time Intelligence que vimos 
en el capitulo anterior ya podemos construir esta variation. 
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Para finalizar la construccion de nuestro reporte parametrizado, 
vamos a agregar la medida a la tabla dinamica y crearemos un slicer 
a partir de la tabla desconectada con el campo Umbral. 


Pais 

Q Utilidad - Rango 

Argentina 

54.460,3085 

Brasil 

46.774,0040 

Chile 

47.739,2280 

Colombia 

51.723,2500 

Ecuador 

47.126,6260 

Paraguay 

50.206,2590 

Peru 

48.769,8735 

Uruguay 

45.869,3350 

Venezuela 

51.841,6335 


Total general 444.510,51 75 



Figura 11.13- Combior Escala 


Para entender el comportamiento de nuestros compradores y 
generar una polftica de descuentos robusta y basada en datos, 
adicionalmente, crearemos una medida que funcione en conjunto 
con el slicer ya creado y que nos muestre la cantidad de 
compradores por cada rango y en cada pais. 


Rango[Compradores/Rango]:= 

COUNTROWS ( FILTER ( TABLA_Pedidos, 

TABLA_Pedidos[Unidades] >= MAX ( Rango[Menor]) 
&& TABLA_Pedidos[Unidades] < MAX ( Rango[Mayor]) 

) 

) 
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Finalmente, agregamos la medida al area de valores de la tabla 
dinamica y el reporte debe tener el siguiente aspecto 


Pais 

Q Utilidad - Rango 

Comp rad o res/Rango 

Argentina 

110.827,1440 

909 

Brasil 

111.096,4540 

966 

Chile 

113.551,0530 

907 

Colombia 

112.244,1000 

919 

Ecuador 

114.828,6420 

949 

Paraguay 

108.655,3630 

918 

Peru 

102.829,7670 

882 

Uruguay 

100.708,2200 

896 

Venezuela 

1 1 1.688,8820 

890 


Total general 986.429,6250 8.236 


Umbral ^ 


Mayor a I y Menor que 2 


Mayor a 2 y Menor que 3 


Mayor a 3 


Figura 11.14- Reporte Finalizado 


Al elegir otro rango en el slicer, ambas columnas de la tabla 
modificaran sus calculos, algo muy elegante y util, porque 
rapidamente podemos obtener informacion, para entender una 
parte del comportamiento de los compradores en diferentes paises, 
con ello se puede crear una politica de descuentos. 


Adicionalmente, queremos mencionarte que en un mismo reporte 
puedes agregar el numero de tablas slicer que requieras, no tienes 
ningun Ifrmite para agregar estos elegantes elementos a tus 
reportes, y como ya te hemos dicho, puedes expandir las tablas 
slicer a casi cualquier escenario, recuerda que le brinda la 
posibilidad al usuario de establecer una comunicacion con el 
reporte, para analizar diferentes situaciones dado un parametro o 
diferentes rangos. 
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El Siguiente Paso 

Despues de una buena dosis de parametrizacion con tablas slicers 
para diferentes escenarios comunes, es tiempo de adentrarnos 
mas en Los tipos de relaciones entre tablas y sus implicaciones, lo 
cual es la tematica del siguiente capitulo. 




La Presente Pagina se ha dejado en Blanco de forma deliberada. 




Capitulo 12 


Multiples Tablas Base y Relaciones 

Avanzadas 
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Prologo a Relaciones Avanzadas y 
Multiples Tablas Base 

NOTA 


SSAS Tabular: SQL Server 
Analysis Services Tabular. 

Si en algun punto 
necesitas mas poder que 
el ofrecido por Power 
Pivot, lo puedes obtener, 
por ejemplo, si necesitas 
archivos de mas de dos 2 
GB, entonces necesitas 
mas potencial. SSAS 
Tabular es Power Pivot 
Turbo, es decir, el 
hermano mayor de Power 
Pivot que te permite ir aun 
mas alia. 


A lo largo de los ultimos capitulos nos hemos centrado 
vigorosamente en el lenguaje DAX, y si, teniamos que hacerlo; no 
solo por todos los beneficios y maravillas que podemos lograr con 
el, sino por todas las implicaciones que derivan de ello, ya que es 
la espina dorsal de las tecnologias de Microsoft Business 
Intelligence. El lenguaje DAX esta presente en: 


■ SSAS Tabular 

■ Power Bl (.com) 

■ Power Bl Desktop 

■ Power Pivot for Share Point 


En SSAS Tabular se puede 
programar en visual 
estudio, restringir 

modulos para acceso 
especifico en momentos 
del dia o para ciertas 
personas, su nivel de 
seguridad es 

supremamente elevado, 
entre muchos otros 
beneficios. 

Igualmente, SSAS Tabular 
tiene como espina dorsal 
el lenguaje DAX, por lo 
que si necesitas moverte a 
estas ligas lo pudes hacer 
de forma natural. 


Por lo tanto, si deseas ir a explorar y profundizar en algunas de las 
tecnologias listadas, lo puedes hacer debido a que ya conoces el 
cerebro de cada una: El DAX Engine. De hecho, una vez termines de 
estudiar, profundizary dominareste texto te recomendamos Power 
Bl como proximo destino en el mundo Microsoft Business 
Intelligence. 

Este capitulo no sera la excepcion, es decir, lo que estudiemos aqui 
tambien es perfectamente valido para Power Bl y sus colegas, y es 
que a diferencia de los capitulos previos donde todo giraba 
alrededor del lenguaje DAX, ahora vamos a sumergirnos en las 
diversas relaciones entre tablas y el abanico de conceptos y 
consideraciones que encontramos al navegar por esas aguas. 
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Pausemos un Momento 

Permitenos oclaro algo: Aunque el titulo e introduction del capitulo 
tlene la palabra avanzado, la verdad es que a estas alturas la 
tematica que sera tratada a continuation no tlene absolutamente 
nada de compleja, comprenderlas, sabemos que no tendra mayores 
complicationes. Con la palabra avanzado mas bien queremos dar 
entender: (el siguiente paso); entonces: /Que empiece la Diversion! 


Multiples Tablas Base o Matrices 

Demosle un vistazo a la vista de diagrama, ya sabes, para refrescar 
la memoria de como va el entretejido de tablas. 


EE TABL... 

EE Descue... 

EE SKU Pro... 

EE Calend... 


EE SKU 

EE Descuent... 

EE SKU 

EE Fecha 

* 

EE Categorfa 

EE Categorfa... 

EE Producto(s) 

EE Ano 


SI Precio de... 


EE SumaAgr... 1 

EE Mes Nu... 




EESumaAgr... v 

EE Mes No... 

V 



* * * * 


m TABLA_Pedidos 

IE Numero de Pedido 
EE Tipo de Compra 

ee sku 

EE Categorfa de Descuento 
EE Precio de Venta 

□ Unidades 

□ Costo del Producto 

□ Costo de Envio 
EE Costo Empaque 
EE Fecha de Envio 
SI Fecha de Llegada 
EE Pais 

EE Ciudad 
EE Costo Total 


NOTA 

En la figura unicamente se 
muestran las tablas que 
estan relacionadas, las 
tablas desconectadas se 
omitieron, pues el objetivo 
en este capitulo es 
centrarnos netamente en 
los diversos tipos de 
relaciones. 



Figura 12.1 - Entretejido de Tablas Hasta Aqui (Sin Tablas Desconectadas) 
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NOTA 

En el mundo de bases de 
datos y Cubos OLAP (Si, 
Power Pivot es un Cubo 
OLAP, asi que ya puedes 
decir que sabes sobre 
desarrollo OLAP), se les 
denomina tecnicamente a 
las tablas base como 
tablas de hechos (Fact 
Tables) y a las tablas de 
busqueda: tablas de 

dimension (Dimension 
Tables), estos son los 
terminos precisos y 
exactos para cuando los 
veas o estudies por alii. A 
pesar de lo anterior 
seguiremos utilizando en 
este libro nuestros 
terminos: Tablas Base y 
Tablas de Busqueda. 


Recordemos tambien que La tabLa hacia donde apuntan las flechas 
(jOjo! En Excel 2016 y Power Bl, en 2013 y 2010 es, al contrario) la 
llamamos tabla base o matriz. La tabla base es aquella que tiene la 
clave externa (donde se repiten los elementos a lo largo de la 
columna). Por otra parte, las tablas de busqueda, son quienes 
albergan la clave principal (donde NO se repiten elementos) y sirven 
en esencia como tablas de informacion. 

En la construccion de nuestro modelo de datos tenemos varias 
tablas de busqueda, incluso una especial que es La de calendario, 
siguiendo este hilo nos podemos preguntar ahora. 

tSerd que no podemos contar con mas de una tabla matriz? 

Porque si lo meditamos por un instante, es logico que nos 
encontremos en la compania con otras tablas con estas 
caracteristicas, pues para cada proceso es 99-9% seguro que se 
generan registros dias tras dias y otros datos relacionados con el 
proceso. 


Extendiendo el 
Escenario de la 
Compama 


Metamonos un poco mas en el escenario de la compania que 
hemos estado trabajando en este libro, resulta que la compania no 
se dedica unicamente a distribuir los articulos (Libros, DVD, CD, etc.) 
sino que tambien cuenta con la planta de produccion para crearlos, 
con lo cual, a su vez se dedica a proveer con dicho material a otras 
distribuidoras; entonces, si nos vamos a la planta de produccion es 
natural que nos encontremos con un registro de datos que nos 
indique en los diversos dias La produccion. Y si, de hecho, este es 
el caso. 
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He aqui La tabla: TABLA_Produccion. 


SKU 

-43 Fecf, ° 0 

Cantidad Tiempo de Produccion |~7| Bodega |V| 

BO 6 

1 /12/1999 

ISO 

12 All Out 

BO 6 

I/I 2/1999 

ISO 

12 All Out 

CIO 

I/I 2/1999 

216 

14 All Out 

CBOI 

1 /12/1999 

290 

10 All Out 

CCQI 

I/I 2/1999 

264 

12 All Out 

CC02 

I/I 2/1999 

396 

18 All Out 

LO 1 

1/12/1999 

284 

20 All Out 

L02 

1/12/1999 

433 

2 All Out 

LG 3 

I/I 2/1999 

3S9 

10 All Out 

LG4 

I/I 2/1999 

187 

S All Out 


i 


Figura 12. 2 - Tabla Base: Produccion 


Procedamos a conocer cada campo y entender que papeL juegan 
en La tabLa de produccion, a continuacion, se listan y justifican: 



Tabla Base: 
Produccion 


Descripcion de 
Campos 


■ SKU: Es eL identificador que se utiliza para un producto o 
conjunto de productos especificos, en la tabla indica cual 
se produjo en la fecha. 


■ Fecha: Indica el dia especifico en el cual se realizo la 
produccion del producto. 


■ Cantidad: Como su nombre lo indica, senala cuantas unidades se 
produjeron de dicho producto para la fecha sehalada. 


■ Tiempo de Produccion: Tiempo en minutos que tardo la 
produccion deltipo de producto. 

■ Bodega: Este es un campo de texto que puede tener dos valores: 
Alt Out o Sunk, cuando es All Out indican que absolutamente nada 
de la produccion de ese dia quedo en bodega, bien sea por que 
se vendio a clientes directamente en la compania o porque se 
vendio a otro distribuidor. Mientras que Sunk, indica que esa 
produccion quedo en bodega, nunca se vendio. 
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Dandole una mirada cercana a las tablas podremos notar 
rapidamente que tal vez sea posible relacionar el campo SKU de la 
TABLA_Produccion con el campo SKU de la tabla 'SKU Productos'. 
tSera esto posible? Dado queya tenemos relaciones entre tablas. 

Averiguemoslo, pero primero agreguemos la tabla de produccion a 
Power Pivot, esta se genera en un archivo de Excel externo, con lo 
cual podemos agregarla sin ningun problema. 


Asistente para la importacion de tablas ? X 

Conectar a un archivo de Microsoft Excel 

Especifique la informacion necesaria para conectarcon el archivo de Microsoft Excel. 


Nombre descriptive de la conexion: 
Ruta de acceso del archivo de Excel: 


Excel TABLA.Pnoduccidn 


| gy-.Cap rtulo 12MAB LA. Production jdsx| 


Examinar... 


CT Usa r pri mera fi la como enca bezados de col u m na . 


Avanzadas... 


Probar conexion 


Figura 12.3 - Agregando Tabla Produccion a Power Pivot 


No olvides seleccionar la casilla: Usar primera fila como 
encabezado, siguiente y cerrar en el cuadro de dialogo. 


Pausemos un Momento 



Al igual que todos los archivos utilizados en este texto, la tabla de 
produccion puedes encontrarla en el compendio de archivos. Para el 
caso TABLA_Produccion puedes hallarla en la carpeta asociada al 
capitulo numero doce. 
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Ahora bien, procediendo a crear la relacion encontraras lo que Crear Primera 

esperabas: se crea sin ninguna clase de inconveniente, al fin y al Relacion 

cabo, es exactamente los mismo solo que ahora hay mas tablas. 



m TABLA_Pedidos 

□ Numero de Pedido 
ED Tipo de Compra 

ed sku 

ID Categorfa de Descuento 
[D Precio de Venta 
ED Unidades 
ED Costo del Producto 

□ Costo de Envio 
ED Costo Empaque 

□ Fecha de Envio 

□ Fecha de Llegada 
ED Pafs 

ED Ciudad 
ED Costo Total 


SKU 

Fecha 

Cantidad 

Tiempo de Produccion 
Bodega 


Tabla Pedidos | Tabla Base 


Tabla Produccion | Tabla Base 


Haciendo un poco de Zoom para ver 
mas de cerca hacia que tabla apunta la 
direccion de la flecha en la ultima 
relacion, podemos comprobar que 
efectivamente senala a la tabla base, en 
este caso a la recien agregada tabla 
base: Tabla Produccion 


Nota como ahora hay dos "unos" (1) 
en la parte inferior de la tabla 
categorfa de productos, indicando 
que ahora salen dos relaciones, 
donde ese lado de la tabla sirven 
como clave principal. 
-▼- 


Aqui podemos notar a donde llega la 
nueva relacion, donde el asterisco 
nos indica que es el lado de clave 
externa (muchos eiementos). Todo es 
exactamente igual que antes solo 
que ahora tenemos dos tablas bases. 
-▼- 


TABLA_CategoriaDeProductos, Descuentos, SKU ProductosCalendario | Tablas de Busqueda 


] TABL... 

ED SKU 
ED Categorfa/ 
El Precio d,6... 


/"N 


ED Descue... 

ED Descuent... 
ED Categorfa... 


SKU Pro... 


ED SKU 


ED Producto(s) 


ID Suma Agr... 


ID Suma Agr... 


ID Calenda... 
ED Fecha 

□ Ano 

ED Mes Nu... 

□ Mes No... 


Figura 12. 4 - Primera relacion entre las tablas produccion y una de las tablas de busqueda 
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NOTA 

Ffjate en como no existe 
ningun tipo de relacion 
entre la tabla Descuentos y 
la tabla Production, esto 
es bastante frecuente, 
pues hay informacion que 
solo concierne a ciertos 
procesos. 


AnaLizando las tablas de busqueda y la nueva tabla base, podemos 
llegar facilmente a que estas son las relaciones: 



Tabla de Relaciones para la Nueva Tabla Base 


Tabla de Busqueda 

Tabla Base 

TABLACategoriaDeDescuento[SKU] 

TABLA_Produccion[SKU] 

'SKU Producto'[SKU] 

TABLA_Producdon[SKU] 

Calendario[Fecha] 

TABLA_Pedidos[Fecha] 


El entretejido de tablas quedaria: 


El TABL... 

E3 Descue... 

El Descuent... 

5 Categorfa... 

El SKU Pro... 

5 Calenda... 

| |E3 SKU 

e sKU f 

| 5 Fecha | 2 

5 Categorfa 

5 Precio de... 

5 Producto(s) 

5 Suma Agr... 1 
5 Suma Agr... v 

5 Ano 

E3 Mes Nu... 

E3 Mes No... v 


53 TABLA_Pedidos 

□ Numero de Pedido 

□ Tipo de Compra 

□ SKU 

□ Categorfa de Descuento 

□ Precio de Venta 

□ Unidades 

□ Costo del Producto 

□ Costo de Envio 
n Costo Empaque 

□ Fecha de Envio 

□ Fecha de Llegada 

□ Pafs 

53 Ciudad 

□ Costo Total 


© 


□ Produccion 


n sku 


^Fech^ 


51 Cantidad 

5 Tiempo de Produccion 
5 Bodega 


Nota: No se hizo relacion entre las tablas base, Power 
Pivot no permite tal cosa, relacion muchos a muchos 
por lo menos directamente. 


Figura 12.5 - Todas las Relaciones de las Tablas de Busqueda Hacia la Tabla Production 


Evidentemente, si tenemos mas de dos tablas bases, no habra 
ningun inconveniente en relacionarlas con las tablas de busqueda; 
no obstante, nota como no se ha creado una relacion que sea 
directamente entre las tablas base. 
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jToma Nota! 



La relation entre tablas base serta del tipo: Muchos a Muchosy Power 
Pivot no lo permite, si se intenta, por ejemplo, relationar los campos 
SKU o fechas, Power Pivot mostrara un error inevitable. Pern, 
podemos llevar a cabo dicha relation en Power Pivot con ayuda de 
tablas intermedias, veremos esto mas adelante en el presente 
capitulo. 


Cuadro de Dialogo Relaciones 

Estando en Excel 2016 podemos ir a la pestana DATOS, grupos 
HERRAMIENTA5 DE DATOS y clic en el comando RELACIONES. 


^ Datos J Revisa r 

Vista Desarrollador Power Pivot Analizar Diseno 

0 ^Que desea hacer? 

RH Mostrar consultas 
§ Desde una tabla 

Eq Fuentes recientes 
;nery transformar 

[jpfc| S Conexiones 
[H] Propiedades 

Actualizar 

todo ' r Editar vmculos 

Conexiones 

w IS® T tT 

Tg Volver a aplicar 

Z 1 Ordenar Filtro _ 

A * T*' Avanzadas 

Ordenar yfiltrar 

m m b-i ^ 

Texto en Relleno Quitar Validacion Consolida 

columnas rapido duplicados de datos 7 

Herramientas de datos 

Relaciones 

6£ 

Administrar 
nodelo de datos 


I 


Figura 12. 6 - Comando Relaciones en la Pestana Datos 


Con esto se despliega el siguiente cuadro de dialogo. 



Figura 12. 7 - Cuadro de Dialogo Administrar Relaciones 
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: 



Para Excel 2013 puedes desplegar el cuadro de dialogo dejando la 

celda activa dentro dela tabla dinamica para asi tener acceso a la 

pestana contextual ANALIZAR, grupo CALCULOS, comando 

RELACIONES. 

Medidas de 
Multiples Tablas 
Base 

Medidas de Multiples Tablas Base 

Digamos que necesitamos ver en un reporte de tabla dinamica 

todas las unidades vendidas en los distintos anos, tanto para la 

distribuidora de la compama como en la planta de produccion. 

Espedficamente detallado para los meses del ano 2014. 

Medida Unidades Ventas en la tabla Pedidos : 

NOTA 

Tabla_Pedidos[Unidades Ventas]:= 

SUM(TABLA_Pedidos[Unidades]) 

Ffjate como se ha utilizado 
la funcion CALCULATE 
para crear un filtro en el 
campo Bodega para 
aquellos que sean All Out, 
pues como se vio en el 
analisis exploratorio de la 
tabla produccion, 

solamente aquellos que 
digan All Out SALIERON 

DE BODEGA PARA 

VENTAS, bien sea para la 
distribuidora de la 

companfa o para proveer 
otras empresas. 

Medida ContidodesMe ntas en la tabla Produccion-. 

Produccion[Cantidades]:= 

CALCULATE( SUM('Producci6n'[Cantidad]); 

, Producci6n l [Bodega]="All Out") 

Creemos la tabla con la siguiente configuracion: los Campos Ano y 

Mes Nombrede la tabla Calendarioa l area de filas, y las dos medidas 

recien creadas al area de valores. Contraemos todos los anos y 

unicamente dejamos los meses visibles para el 2014. 


iTu que dices? - iFuncionara? Averiguemos-> 
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Etiquetas de fila pi Unidades Ventas Cantidades 


1999 

117 

3620 

2014 

4017 

75745 

Enero 

347 

5650 

Febrero 

300 

6380 

Marzo 

318 

5839 

Abril 

350 

6263 

Mayo 

325 

6237 

Junio 

327 

6317 

Julio 

364 

6798 

Agosto 

362 

5768 

Septierribre 

298 

6780 

Octubre 

368 

5345 

Noviermbre 

320 

7212 

Diciembre 

338 

7156 

2015 

4690 

72272 


Figura 12. 8 - Tabla Dindmico con Medidas de Multiples Tobias Bose 


l?or que funciona? - Porque, como vimos en el capitulo siete, los 
filtros de las tablas de busqueda se propagan hacia las tablas base, 
en este caso, son dos, y funciona correctamente. 

Medidas Hfbridas 

Pero la tabla dinamica no esta mostrando lo que necesitamos 
exactamente, pues a Cantidades se le debe restar las Unidades que 
fueron para la distribuidora de la compama. <- Sera que podemos 
hacer un cruce entre medidas de distintas tablas base y realizar esta 
resta? 


jAVERIGUEMOSLO! 




NOTA 

Detengamonos por un 
instante y reflexionemos 
en todas las piruetas que 
tendriamos o que 
tenfamos que hacer para 
lograr un reporte como el 
de la figura. 

La solucion clasica: poner 
dos tablas dinamicas, una 
con unidades de ventas de 
acuerdo a la tabla base 
Pedidos y otra con las 
cantidades de la tabla 
Produccion; otra 

alternativa, con alquimia 
de formulas y funciones, a 
pesar de contar con estas 
vfas de solucion, cualquier 
cambio en la forma del 
reporte que nos solicitaran 
nos hacia empezar de 
ceros, en cambio con esta 
alternativa solo hace falta 
quitar, agregar o arrastrar 
lo que sea necesario a las 
areas de colocacion y el 
reporte se ajusta en 
cuestion de segundos. 

iNo es eso Esplendido? 
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Producci6n[Unidades Proveidas]:= 


[Cantidades]-[Unidades Ventas] 


La tabLa dinamica: 


Etiquetas de fiila Unidades 

Ventas Unidades 

Proveidas i 

Cantidades 

O 1999 

117 

3503 

3620 

P2GI4 

4017 

71728 

75745 

Enero 

347 

5303 

5650 

Febrero 

300 

6080 

6380 

Marzo 

318 

5521 

5839 

Abril 

350 

5913 

6263 

Mayo 

325 

5912 

6237 

Jynio 

327 

5990 

6317 

Julio 

364 

6434 

6798 

Agosto 

362 

5406 

5768 

Septiembre 

298 

6482 

6780 

Octubre 

368 

4977 

5345 

Noviennbre 

320 

6892 

7212 

Diciermbre 

338 

6818 

7156 

O2015 

4690 

67582 

72272 


Figura 12. 9 - Reporte de Tobio Dindmico con Medida Hibrida 


tSorprendido por quefunciona?- ProbabLemente no, iYa to habias 
intuido verdad?- porque, como recordaremos del capitulo siete, el 
calculo o aritmeticas de las medidas se ejecutan en el penultimo 
paso justo antes de retornarlo a la tabla dinamica. Debido a que los 
filtros ya se han aplicado, se obtiene los valores justos de cada 
medida base arrojando el valor que queriamos. En conclusion, 
podemos utilizar medidas hibridas, es decir, medidas creadas a 
partir de operaciones entre medidas de tablas base. 
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Consideraciones Multiples Tablas Base 

Si se crean tablas dinamicas y medidas cuando hay multiples 
tablas base en el modelo de datos, es importante tener claro 
ciertas consideraciones para evitar resultados inesperados y 
confusos. 


Evita utilizar los campos de una tabla base especifica cuando Consideracion 

utilices medidas hfbridas en el reporte, por ejemplo, si en lugar de 

utilizar los campos Ano y Mes nombre de tabla Calendario, usamos 

Fecha de Envio (Ano) de la tabla base Pedidos, obtendremos 

resultados extranos, tanto para la medida de la segunda tabla base 

(Produccion) como para le medida hibrida. 



Total general 49461 1207956 j 1158495 


Figura 12.10- Utilizando Compos de uno To bio Bose cuondo hoy Medidos Hibridos 
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jToma Nota! 


O RECALCANDO Y REPASANDO: La Propagation de Coordenadas para 
aplicar filtros unicamente ocurre de las tablas de busqueda a la tablas 
base, es detir, la propagation no sucede de la tabla base a las de 
busqueda, los filtros en la tabla base solamente la afectan a ella y nada 
mas. Esto es extremadamente importante. Esto es tan importante que 
| sentlmos la necesidad de dejarlo aqut nuevamente. 


Tabla Dinamica de la Figura 12.9 



Tabla Dinamica de la Figura 12.10 



S3 Calenda... 
S3 Fecha 
S3 Ano 

□ Mes Nu... 

□ Mes No... 


La Tabla de Calendario Queda 
Intacta 


n campo de una tabla base entonces la tabla de 


It * * 

S3 TABLA_Pedidos 




Como es un campo de la 

a 

1 S3 Fecha de Envio 1 


S3 Fecha de Llegada 
m D^.'e 

tabla base se aplica el filtro. 



-omo es ur 

busqueda runca sentira el efecto, ya que no se propaga en 
sste sentido 


S3 Produccion 

m sku 

□ Fecha 
S3 Cantidad 

HI Tipmnn Hp PrnHnrrinn 


En definitiva, la tabla base 
produccion queda intacta (No 
siente ningun filtro de fecha) 
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Repitiendo y escarbando en La propagacion de filtros, tal vez esto 
es algo repetitivo y sonemos algo "cansones", la verdad es que es 
tan importante que no queremos dar ni la mas diminuta 
posibilidad a que sea confuso. Con multiples tablas base era algo 
que definitivamente debiamos enmarcar y visualizar con cierto 
grado de detalle. 


Utiliza las tablas de busqueda compartidas o comunes a todas las Consideracion 

tablas base, de otra manera se generan tablas dinamicas ambiguas, 
por ejemplo, agreguemos el campo Categoria de Descuento en el 
area de filas y dejemos las dos medidas anteriormente creadas. 


Etiquetas de fila Q Unidades 

Ventas 

Cantidades Unidades Proveidas 1 

Balck Fraday 

3927 

1207956 

1 204029 

Cyber Monday 

13668 

1207956 

1194288 

Day Off Full 

2958 

12^^ 

1204998 

Non 

26616 


1181340 

Special Day 

2292 

1207956 

1205664 

Total general 

49461 

1207956 

1158495 


Esta medida basada en campos de 
la tabla base Produccion, no tiene 
absolutamente nada que ver con las 
categonas de descuento que solo 
concierne a la tabla Pedidos (base), 
sin embargo, un tercero podna 
asumir que las cantidades 
producidas estaban asociadas algun 
lote para descuento, por ejemplo, 
ediciones especiales y/o limitadas. 


Figura 12.12 - Reporte que Utiliza Campo de ana Tabla de Busqueda que no es Comun 



Pausemos un Momento 

Teniendo claras las consideraciones, hacer uso de multiples bases es 
mas seguro, de hecho, despues de la lectura seguramente sera mas 
intuitivo y Idgico para el lector, por lo que estas casos seran 
manejados de manera natural y sin ningun inconveniente. Estamos 
seguros de ello. 
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Relaciones Avanzadas 

Ahora si veamos ciertas relaciones con las cuales podemos lograr 
modelos de datos mas robustos. 

Varias Relaciones Entre un Par de Tablas 

Hasta ahora, el campo Fecha de Envio de la tabla Pedidos ha sido la 
relacion con el campo Fecha de la tabla de Calendario, por lo tanto, 
las base para nuestro analisis, pero imaginemos el siguiente 
escenario: supongamos que deseamos conocer los ingresos de 
acuerda a la Fecha de Llegada de los productos, lo cual, es un 
escenario bastante interesate porque se puede basar los analisis en 
ingresos 100% generados, debido a que aseguramos que no existio 
ningun percance. 

Pero lo anterior, requiere que la relacion sea con el campo Fecha de 
Llegada. iPareceria que tal cosa llevaria a un error inevitable? 
Miremos a ver que pasa: 






Figura 12.13 - Creondo Nuevo Relacion Entre Por de Tobias yo Relocionodos 
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cEsperabas un error no es asi?- Pero, todo lo contrario, ha ocurrido 
algo bien interesante, mirennos las buenas nuevas. 


TABLA_CategoriaDeProductos, Descuentos, SKU Productos, Calendario | Tablas de Busqueda 


53 TABL... 

m sku 

CHI Categorfa 

El Precio de... 

CO Descue... 

CD Descuent... 

B Categorfa... 

cm SKU Pro... SID 
B SKU 

CD Producto(s) 

B Suma Agr... 

CTI Suma Agr... 

B Calenda... 

| B Fecha 

B Ano 

□ MesNu... 

cm Mes No... v 

1 V 

1 l\ 



La relacion se ha 
creado pero esta vez 
su representacion 
visual es una linea 
punteada. 

Las relaciones con 
lineas solidas 
significan que estan 
Activas, mientras que 
las de lineas 
punteadas Inoctivas. 


Las dos relaciones entre las tablas 
Pedidos y Calendario se puede ver 
graficamente que se mantienen. 


Figura 12.14 - Relacion Linea Punteada, Relacion Inactiva 


jToma Nota! 



iDE NINGUNA MANERA! iDe Verdad? Podemos apreciar que las dos 
relaciones estan presentes entre el par de tablas (Pedidos y 
Calendario), donde la primera es una linea solida, mientras que la 
recien creada es una linea punteada, esto significa que dicha relacion 
esta inactiva, basicamente porque en cualquier instante en el tiempo 
solo una relacion entre un par de tablas puede estar activa. 
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Si vamos at cuadro de dialogo relaciones podremos observar 
claramente cuales estan activas e inactivas. 


Administrar relaciones 


? 


X 


Estado 

Tabla 

Tabla de busqueda relacionada 

Activo 

Produccion (Fecha] 

Calendario (Fecha) 

Activo 

Produccion (SKU) 

5KU Pro duct os (SKU) 

Activo 

Produccion (SKU) 

TABLA_CategorfaDeProdudos (SKU) 

Activo 

TABLA_Pedidos (Categori'a de Descuento) 

Descuentos (Categori’a de Descuento) 


TABLA Pedidos (Fecha de Envio) 

Calendario (Fecha) 

Inactivo 

TABLA Pedidos (Fecha de Llegada) 

Calendario (Fecha) 

Activo 

TABLA_Pedidos (SKU) 

TABLA_Categon'aDeProductos (SKU) 

Activo 

TABLA_Pedidos (SKU) 

5KU Productos (5KU) 


Nuevo... 


Deteccion automatica... 


Modificar... 


Activar 


Desactivar 


Eliminar 


Figura 12.15 - Observando Estodo de Relaciones: Activo o Inactivo 


Con el boton Activar en la parte derecha del cuadro de dialogo 
podemos activar o desactivar las relaciones, no obstante, que 
sucede si queremos ver los ingresos basados tanto en la Fecha de 
Envio como en la Fecha de Llegada, uno al lado del otro a lo largo 
de los anos en un mismo reporte de tabla dinamica. La solucion, la 
funcion: USERELATIONSHIP. 


USERELATIONSHIP 

La funcion USERELATIONSHIP, especifica una relacion entre un par 
de tablas para ser utilizada en calculo concreto, entre un par de 
columnas senaladas en sus argumentos. 

Sintaxis USERELATIONSHIP(Columnal; Columna2) 


Funcion 

USERELATIONSHIP 



Argumentos de la Funcion USERELATIONSHIP 


Argumento Description 

Columnal Columna de la primera tabla (Clave Externa) 
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La funcion USERELATIONSHIP es bastante ''especial", pues no 
retorna ningun valor, dado que unicamente establece la relacion 
durante el tiempo de calculo; es diferente, a las funciones que 
hemos venido trabajando, pero es sencilla de entender. 

Creemos la medida para ver su funcionamiento: 


[Ingresos por Fecha de LLegada]:= 

CALCULATE! [Ingresos]; 

USERELATIONSHIP(TABLA_Pedidos[Fecha de Llegada];Calendario[Fecha])) 


En este preciso instante podemos poner la medida Ingresos e 
Ingresos por Fecha de Llegada una al lado de la otra sin ningun 
problema. 


Etiquetas de fila Ingresos 

Ingresos por Fecha de Llegada 

El 1 999 

$8,685.83 

t 

El 2000 

$180,680.24 

$ 1 82,6 J 4.8T 

El 2001 

$166,860.36 

$ 1 68, . 2 1 .85 

El 2002 

$184,876.83 

$I84,048>^ 

El 2003 

$ 1 77,061.95 

$177,587.81 

El 2004 

$168,059.37 

$165,946.88 

El 2005 

$ 1 87,906.44 

$190,600.41 

El 2006 

$198,797.54 

$196,793.34 

a 2007 

$ 1 70,7 1 2.79 

$173,730.49 

a 2008 

$175,936.37 

$174,180.51 

El 2009 

$198,222.01 

$ 1 74, 1 97.59 

a 201 o 

$240,873.82 

$191,255.24 

a 2011 

$216,088.04 

$171,751.07 

[+ 2012 

$229,644.13 

$ 1 83,368.2 1 

a20l3 

$232,463.65 

$187,033.05 

a 201 4 

$256,692.19 

SK5J28.2S 

a 201 5 

$327,323.99 

$182,627.14 

EBfen bianco) 


$451,670.06 

Total general 

$3,320,885.54 

$3,320,885.54 


Funciona de la manera esperada, los 
ingresos desfasados en cierta proporcion 
porque una vez sale el producto, toma 
unos cuantos dias en llegar a las manos de 
cliente, la primera celda en bianco lo aclara 
ya que las operaciones del a compania 
empezaron tarde en 1999, por lo tanto, los 
ingresos empiezan a sumar desde el ano 
siguiente 


^Puedes decirnos por que ha aparecido 
este BLANK? 

Tomate un par de minutos y dinos la 
respuesta. ^Listo? 

Porque la tabla de calendario solo llega 
hasta el 2015, mientras que la columna 
fecha de llegada tiene fechas posteriores, 
2016, 2017 y hasta 2018. 



Figura 12.16- Medidos de Diversas Reloci ones Entre un Mismo Por de Toblos 
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jToma Nota! 



La funcion USERELATIONSHIP es empelada en funciones que reciban 
como argumentos filtros, las mas familiar y extendida: CALCULATE, 
por tal motivo la utilizamos en el ejemplo previo, a pesar de ello, hay 
otras funciones que reciben filtros en sus argumentos, como: 
CALCULATETABLE, CLOSINGBALANCEMONTH y su familia, 
OPENINGBALANCEMONTHy su familia, y TOTALYTDy su familia. 


Relacion Muchos a Muchos (Many To Many) 

Hemos visto que Power Pivot solo trabaja con el tipo de relacion 
uno a muchos (en consecuencia, uno a uno, "tambien"). Pero, Power 
Pivot no soporta la relacion muchos a muchos, por ejemplo, si 
tratamos de relacionar las tablas base Pedidos y Produccion 
mediante sus campos de fecha, entonces saldra el siguiente error 


Power Pivot para Excel 

X 

No se puede crear la relacion porque cada coliuimna contiene valorem duplicados. Seleccione al menos una columna que 


co nte n g a s o 1 arnente val o res unices . 




Aceptar 



Figura 12.17 -Error Relacion Muchos a Muchos Directamente 



Pausemos un Momento 

El mensaje del error es bastante claro, falta una clave principal, es 
mas, la relacion que tratamos de hacer carece de sentido, por tal 
motivo Power Pivot no permite este tipo de relaciones, generalmente 
son relaciones que carecen de sentido logico (Recuerda ademas que 
dijimos que las tablas base no se relacionan directamente). 
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Aunque Power Pivot, es amable al evitar complicaciones con las 
relaciones muchos a muchos, si que hay escenarios donde tienen 
sentido y aplicabilidad. 

Many To Many: Validas e Invalidas 

Para aterrizar la relacion muchos a muchos, veamos en que 
circunstancias son validas y cuales carecen de sentido. 


Cuando tenemos un elemento, el cual puede pertenecer a dos Valido 

categories de otra caracteristica, en dicho caso la relacion muchos 
a muchos es valida, por ejemplo, una pelicula puede tener dos 
generos y estos se pueden superponer con otros generos de una 
pelicula diferente, un "grafico" sera mas claro: 


Peifcuia 


Interstellar 

Interstellar 

Capitan America II 

Capitan America II 

X-Men 

X-Men 


^ Genero ^ Duracian (Min) T Rating -E 

Ciencia Ficcion--4.2 

Drama_ 169 H HlX 

Ciencia Ficcion 135 3.8 

Accion 135 3.8 

Ciencia Ficcion J_3I 4.1 

Accion 



El elemento de la columna 
Peliculas pertenece a dos 
categorias de la Columna 
Genero: Ciencia Ficcion y Drama. 


Otro elemento de la columna 
Peliculas pertenece a la categoria de 
la Columna Genero: Ciencia Ficcion. 


Figura 12.18 - Tobla de "Busqueda", Muchos a Muchos Valido 


Tal vez estes pensado: Ok, esa seria la tabla base, sin embargo, 
dada la informacion que contiene, se orienta mas una Pseudo- 
tabla de busqueda, esto es mas claro cuando vemos la tabla de 
ventas de la sala de cine. 
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Fecha [T] Haro [Tj Pelfcuta [T| Entradas [T] 


lunes, 1 de Septiembre de 20 14 12:50 p.m 

Interstellar 

19 

1 tines, 1 de Septiembre de 2014 12:50 p.m 

Capitan America II 

1/ 

lunes, 1 de Septiembre de 20 14 12:50 p.m 

X-Men 

19 

lunes, 1 de Septiembre de 2014 12:50 p.m 

Guardianes de la Galaxia 

19 

lunes, 1 de Septiembre de 2014 12:50 p.m 

Planeta de lo Simios 

15 

lunes, 1 de Septiembre de 2014 12:50 p.m 

Al filo del Manana 

12 

lunes, 1 de Septiembre de 2014 12:50 p.m 

Godzilla 

1/ 

lunes, 1 de Septiembre de 2014 12:50 p.m 

Hobbit 

19 

lunes, 1 de Septiembre de 2014 12:50 p.m 

Spiderman 

10 


i__ i c, — iai a n.cn —^ Di-ik n r-— n 


Figura 12.19- Tabla Bose, Ventos poro la Solo de Cine 


Este si es una tabta base, ya que et hecho de contener datos dia a 
dia funciona como transacciones (alta densidad de datos). 


jToma Nota! 



Las categonas a las cuales pertenecen los elementos de una primera, 
deben ser de la mlsma, es declr, las pelLculas pertenecen a varias 
categonas de genero. El caso en que pertenezcan a varias categonas, 
pern de diversas columnas, ejemplo: Sabor=Dulce y 
Empaque=Plastico, no cuenta como relacion muchos a muchos (Esta 
situation se da el 98% de los casos) 


Invalidos EL otro lado del espectro son las relaciones muchos a muchos que 

no se superponen, por consiguiente, son invalidas, ejemplo: 


Pais 

Continents 

Francia 

Europa 

Jap on 

Asia 

Mexico 

America 

Colombia 

America 
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Teniendo esto claro iComo hacemos para crear relaciones muchos 
a muchos validas? Tomemos el escenario de la sala de cine y 
agreguemos las tablas al modelo de datos, incluyendo una de 
calendario (Una vezse conocen no pueden faltar). 


Calendario \ Tabla de Busqueda 


Esta seria la tabla de busqueda ya que 
por las caracteristicas de sus datos es 
mas proxima este tipo de tabla, pero 
no cuenta con una clave principal, por 
lo cual le hemos denominado 
Pseudo-Busqueda. 


m Ventas 
M Feeha 
[H] Hora 

- * M Pel feu I a 
D Entradas 

Ventas \ Tabla Base 


[D Calend... 

H Fecha 

1| 

ID Affio 


B Mes Nu... 


E3 Mes No... 



[D Peliculas 


M Pel feu la 


[H] Genero 


□ Duracio... 


un Rating 



Pel feu las | Tabla de Pseudo-Busqueda 


Figura 12.21- Visto de Diagromo Tablas Sala de Cine 


Supongamos, por ejemplo, que queremos crear un reporte de tabla Reporte a 

dinamica que muestre el numero de entradas de acuerdo a los Crear 

distintos generos. Para ello debemos relacionar las Peliculas y 
Ventas de alguna forma. 

Tablas Intermedias 

Sabemos que no podemos relacionar este par de tablas 
directamente, ya esta mas que claro, pero indudablemente algo 
podemos hacer. Para abordar el problema necesitamos un par de 
tablas intermedias. 



La primera tabla es facil de identificar, solamente cogemos el 
campo por el cual queremos categorizar la tabla dinamica .... 


Tabla de Filtro 
Intermedia 
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NOTA 

Obtener la tabla de filtro 
intermedia es bastante 
sencillo, solo toma la 
columna deseada, en este 
caso Generos que 
contiene la tabla pelfculas 
copiela y pegala en una 
nueva hoja, seleccione la 
columna completa y utilice 
el comando remover 
duplicados que se 
encuentra en la pestana 
DATOS grupo 

HERRAMIENTAS DE 
DATOS, anada el 
encabezado y conviertala 
en una tabla estructurada 
de Excel (Ctrl + T) y 
nombre descriptivo. 


... Y extraemos to valores unicos para construir una tabta que servira 
para arrastrar a las areas de colocacion. 


Filtro I ntermedio 


■ Cambiar tamariO' de la tabla 
Propiedades 


B2 


Li 


2 

3 

4 

5 

6 
7 


Genero 


Ciencia Ficcion 

Drama 

Accion 

Aventuras 

Suspense 


Figura 12. 22 - Tabla de Filtro Intermedio 


Una vez hecho, debemos remover la columna de la tabla de donde 
la extrajimos, es decir, eliminar la columna Genero de la tabla 
Pelfculas, junto con ello remover todos lo duplicados, quiere decir 
que nuestra tabla base Veritas quedarfa. 


Interstellar 

\6S 

4.2 

Capitan America II 

135 

3.8 

X-Men 

131 

4.1 

Guardianes de la Galaxia 

122 

3.7 

Planeta de lo Simios 

131 

3.5 

Al filo del Manana 

1 13 

4 

Godzilla 

123 

3.6 

Hobbit 

144 

4.1 

Spiderman 

142 

3.6 

Robotop 

1 18 

3.3 

Divergente 

139 

4 

Maze Runner 

1 13 

3.9 


Figura 12.23 - Tabla Base Ventas, Removiendo Duplicados 
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Lo que necesitamos ahora es una tabla que conecte la tabla de 
filtros intermedia con la Pseudo-tabla de busqueda. A esta tabla le 
denominamos Tabla de Conexion (Bridge Table en ingles), y tambien 
es facilmente identificable. La tabla de conexion, para nuestro caso 
contiene para cada una de las peliculas todos los generos a las que 
pertenece, ver la tabla sera mas claro: 


TablaDeConexion 

0*0 Quitar duplicados 
Convertir en rango 

Herramie 

H B h Cambiar tarnano de la tabla 

Propiedades 


B2 T i X v f* Pehcula 



A B 

c 

2 

Peifcula 

Genera j^r 


1 1 1 

3 

Interstellar 

Ciencia Fiction 

4 

Interstellar Drama 

5 

Capitan America II Ciencia Fiction 

6 

Capitan America II Action 

7 

X-Men Ciencia Fiction 

8 

X-Men Action 

9 

Guarclianes de la Galaxia Ciencia Fiction 

IQ 

Planeta de lo Simios Ciencia Fiction 

11 

Planeta de lo Simios Drama 

12 

Al filo del Manana Ciencia Fiction 

13 

Al filo del Manana Action 

14 

Godzilla Ciencia Fiction 

15 

Hobbit Action 

16 

Hobbit Aventuras 

17 

Spiderman Action 

18 

Spiderman Aventuras 

19 

Spiderman Ciencia Fiction 

20 

Robocop Ciencia Fiction 

21 

Robocop Action 

22 

Divergente Ciencia Fiction 

23 

Maze Runner Ciencia Fiction 

24 

Maze Runner Suspense 

25 

"14 

Maze Runner Action 

_ J 




Tabla de 
Conexion 
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Realizando Las relaciones quedaria: 


Tabla de Filtro Intermedia 


il Calend... 

E Feclha 
E Ano 
E Mes Nu... 
E Mes No... 


□ Peliculas 

El Pelfcula 

E Duration (... 

E Rating 

E Filtroln... 

E Genero 

a - 


■— a — * 

H TablaD... 

E Pelfcula 

E Genero 


Tabla de Conexion 

$ * 


H Ventas 
El Fecha 
E Hora 
E Pelfcula 
El Entradas 

Ventas | Tabla Base 


Figura 12. 25 - Relaciones con Tablas Intermedia y de Conexion 


Aunque como ya habras intuido, si creamos una tabla dinamica con 
La solicitud no va funcionar. ^Puedes decirnos por que? 


Ventas[Entradas Adici6n]:=SUM(Ventas[Entradas) 


Etiquetas de fila JEjJ Suma de 

Entradas Medida 

Action 

35249 

Aventuras 

35249 

Ciencia Fiction 

35249 

Drama 

35249 

Suspense 

35249 

Total general 

35249 


Figura 12.26 - Tabla Dinamica (Muchos a Muchos) Hasta Ahora 
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Figura 12.27 - La propagacion defiltros no se ejecuta de una tabla base a ana tabla de busqueda (No Norm aim ente) 


Propagacion Inversa 

iPara que nos molestamos con lo anterior entonces? - jPorque Power 
Pivot es Increible! Pues si, contamos con una forma para que Los 
filtros se propaguen de una tabla Base a una Tabla de Busqueda, 
todo lo que hay que hacer es seguir el siguiente Snippet. 

[Nombre de Medida para Relacion Muchos a Muchos]:= 
CALCULATE( ExpresionDAX; Tabla de Conexion') 

Reajustando La medida Entradas Adicion, seria: 


Snnipets para 
Propagacion 
Inversa 


Ventas[Entradas Adicion]:= 

CALCULATE! SUM(Ventas[Entradas]); 
TablaDeConexion 1 


NOTA 

Tambien se puede crear 
una nueva medida si se 
desea. 
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jY SMASH! 


Etiquetas de fib Q Emtradas Adiciom 

Acciom 

20425 

Aventuras 

5705 

Cierscia Ficciom 

32249 

Drama 

5948 

Suspense 

2893 

Total general 

35249 



Figura 12. 28 - Tabla Dinamica con Relacion Muchos a Muchos Correcto 


ALgo magico paso, y La propagacion de la tabla base a La tabla de 
busqueda sucedio, por lo tanto, la tabla dinamica se ha calculado 
correctamente. La magia la hace CALCULATE indicandole como 
argumento de filtro la tabla de conexion completa. 

Snnipet Otra Vez para relacion Muchos a Muchos: 


Snippets Relacion 
Muchos a Muchos 


[Relacion Muchos a Muchos (Propagacion lnversa)]:= 
CALCULATE([Medida];'Tabla de Conexion' 



Pausemos un Momento 

No te preocupes por la teoria del porque funciona el Snnipet de 
Muchos a Muchos, no es necesario sumergirse en ello, en su lugarya 
sabes y cuentas con el patron (Snnipets) para hacer que el filtro se 
propague de una tabla base a una tabla de busqueda para las 
relaciones muchos a muchos. 
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EL Siguiente Paso 

Para enriquecer aim mas nuestros modelos y crear verdaderas 
herramientas de seguimiento y analisis con Power Pivot, vamos a 
hablar de Jerarquias y KPIs, dos funcionalidades de mucha utilidad 
y tacit aplicacion, asf que veamos de que se trata. 




La Presente Pagina se ha dejado en Blanco de forma deliberada. 




Capftulo 13 


Jerarqufas & KPIs: Key Performance 

Indicators 
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Jerarquias 

Para construir un modelo de datos mas intuitivo y amigable con el 
usuario final, debemos tener en cuenta que es posible trazar un 
camino que facilite la busqueda de un dato dentro de un reporte a 
traves del uso de jerarquias de varios niveles, pues bien, 
empecemos a estudiar con lupa todo lo relacionado con esta 
tematica. 

Esencia de una Jerarquia 

(•Que es una Jerarquia? 


Estimado Lector, una Jerarquia es un camino preestablecido en un 

Definicion 

reporte, creado a partir de la anidacion de varios niveles que estan 
relacionados entre si, para facilitar la busqueda y analisis de datos, 
y asi mejorar la experiencia de usuario. iQue tan util es una 
jerarquia? Te estaras preguntando, pues bien, todo depende del 
criterio del creador del reporte, para decidir, que tan conveniente 
resulta utilizar este recurso en un momento particular. 

Cuando crear Jerarquias 

No siempre es buena idea utilizar jerarquias en nuestro reporte, por 
eso debemos tener en cuenta ciertos lineamientos que nos 
ayudaran a decidir si es apropiado el uso de una jerarquia: 


■ Es adecuado crear jerarquias si el reporte va a ser 
compartido, y consultado por varias personas dentro de la 
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organizacion, y que posiblemente desconozcan como se ha 
construido ese modelo de datos. 

■ SI los datos tienen un patron subyacente entre sus 
diferentes campos, por ejemplo, una tabla con Las columnas 
Ano, Mes y Dia, en otras palabras, Los campos tienen un 
patron y una relacion. 

■ Hay que tener en cuenta si el numero de niveles es 
apropiado y esta en equilibrio, no aporta mucho crear una 
jerarquia de un nivel o dos, o, por el contrario, una jerarquia 
de 21 niveles, donde llegar al ultimo nivel, puede terminar 
siendo una compleja tarea. 

Pero te estaras preguntando ^Por que deberia invertir mi esfuerzo 
en crear una jerarquia?, pues estas son algunas razones: 

■ Facilita la busqueda de datos a cualquier usuario que acceda 
al reporte. 

■ Disminuye el tiempo de busqueda de informacion. 

■ Reportes mas intuitivos de analizar. 

En la siguiente figura puedes visualizar una jerarquia de tres 
niveles que muestra los ingresos obtenidos en cada ano, observa 
que intuitivamente se establece una ruta de busqueda que va de 
un nivel superior (Ano) hasta uno inferior (Mes): 
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NOTA 

Otros ejemplos de 
jerarquia pueden ser: 

Categoria de Producto -> 
Subcategorfa de Producto 
Tipo de Producto-> 
Producto -> 

Pais -> Estado -> Ciudad 
-> Cliente -> Direccion del 
Cliente. 


A A 


2 

3 

4 

5 

6 

7 

8 

9 

10 
I I 
12 

13 

14 

15 


B 


C 


Fecha 

"^3 Ingres os 

o 1999 

$8,685,83 

□ 2000’ 

$180,680,24 

±JTril 

$49,429,52 

±JTri2 

$45,700,64 

0Tri3 

$41,992,30 

jul 

$15,729,1 1 

Aug 

$15,056,15 

Sep 

$11,207,04 

dTri4 

$43,557,78 

Oct 

$14,678,72 

Nov 

$14,862,94 

Dec 

$14,016,1 1 

©2001 

$166,860,36 


Figura 13. 1- Jerarquia en una Tabla Dinamica 


Primero, vamos a construir una jerarquia estandar en el modelo de 
datos. 


Construyendo Jerarquias 

Las jerarquias se deben crear en la vista de diagrama del modelo 
de datos, para construir una jerarquia seleccionamos en el orden 
correspondiente los campos que representaran los diferentes 
niveles en la jerarquia, manteniendo presionada la tecla CTRL y con 
clic izquierdo, posterior a ello damos clic derecho sobre algun 
campo seleccionado y elegimos la opcion Crear Jerarquia. Tambien 
puedes crear una jerarquia dando clic sobre el comando Crear 
Jerarquia que aparece en la parte superior derecha de cada tabla 
en la vista de diagrama. 
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u 


ill TABLA_Redldos 


LEU L/iajuc Liiiicga 

f 1 Semanas de Entrega 

A ' 


Ml Fecha de Erwio fano} 


==i Fecha de Envio (trimest 

r ; Crear jerarquia 

[ffl Fecha de Envio (indice c 

1 X Eliminar 


=:i Fecha de Envio (mes) 

Ocultar en herramientas cliente 

ffl AbrevacionT. Compra 

ffl Unidades por Encima 
p Media na Cost. Tot 
p Ingresos 

a 


IS Average of Precio de Venta 



Figura 13. 2- Crear Jerarquia 


SEE TABLAPedidos 

Bsi| 

p INTER Suma Costo Total 
p Utllidad Act 

J Crear jerarquia 

“1“ 

Figura 13. 3- Comando Crear Jerarquia 



En la vista de diagrama se puede ver la nueva jerarquia que hemos 
creado: 


i 


TAB LA Pedidos 


pi Ventas de Alta RentablL. 
pi Erogaciones Apropiada... 
p Venhtas de Alta Rentab... 
p Miaximo de Unidades 
p Ultima Fecha 
p Primera Fecha 


Jerarquia (Fecha) 


Fecha de Envio (ano) 
Fecha de lEnvio (trim... . 
Fecha de Envio (mes) 


Figura 13. 4- Jerarquia en Vista de Diagrama 


Puedes modificar el 
nombre por defecto que 
asigna Power Pivot a la 
jerarquia, dando doble clic 
izquierdo sobre ella y 
luego debes reescribir el 
nombre teniendo en 
cuenta que debe ser 
descriptivo. 
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Modificary 
Agregar Nuevo 
Nivel 


Ademas de modificar el nombre de la jerarqufa, podemos cambiar 
el orden de los niveles, manteniendo presionado el campo dentro 
de la jerarqufa y moviendolo al nivel que deseemos, para agregar 
un nuevo nivel, solo debes arrastrar el campo seleccionado a un 
nivel apropiado dentro de la jerarqufa. Si quieres eliminar un nivel 
de la jerarqufa solo tienes que dar clic derecho sobre el, y 
finalmente, eliges la opcion Ouitar de la Jerarqufa. 


jToma Nota! 



Solo puedes crear jerarquias con campos de la misma tabla, aunque 
si quisieras construir una jerarqufa a partir de varias tablas, lo que 
puedes hacer es crear columnas calculadas a traves del Lenguaje 
DAX, para asf, traer la information de las tablas requeridas y 
finalmente construir la jerarqufa con sus diferentes niveles. 


Con la Jerarqufa creada en el modelo de datos, vamos a crear un 
reporte de Tabla Dinamica, ubicando la jerarqufa en el area de fflas 
y los ingresos en el area de valores. 


Como puedes ver en la figura, en el panel de campos, aparece la 
jerarqufa como si fuera un campo mas de la tabla dinamica, lo cual 
es beneficioso porque a diferencia de crear la jerarqufa de la 
manera clasica (Arrastrando Campos al area de filas de la tabla 
dinamica, como fue creada la jerarqufa de la figura 13.1), puedes 
replicar esta jerarqufa en otras tablas dinamicas sin tener que 
arrastrar campos en cada ocasion, ademas, proteges tu reporte de 
ser modificado por accidente, si por ejemplo, alguien quisiera 
cambiar de lugar los campos. 
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1 Fecha 

Q Ingresos 

+! Q 

B 

□Tril 

$49,429,52 

Jan 

$ 13.508,96 

Feb 

$17,592,04 

Mar 

$18,328,51 

fflTril 

$45,700,64 

BTri3 

$41,992,30 

3Tri4 

$43,557,78 

B 

±!Tri 1 

$42,316,61 

fflTril 

$44,759,01 

fflTri3 

$41,555,91 

±lTri4 

$38,228,83 




Campos de tabla dinami... T x 

ACTIVO TODOS 

Seleecionar campos para agregar al 
informe: 

a SgTABLA_Pedidos 
a J e ra rq u ia (Fecha) 

Fee ha de Envio [a no] 

Fee ha de Envio [trim estre] 

Fee ha de Envio [mes] 
h 1^3 Mas. campos 

Arrastrar campos entre las areas siguientes: 


T FILTROS 

llll COLUMNAS 

= FILAS 

S VALORES 

Jerarquia (Fecha) T 

Ingresos 

T 



Aplazar actualizaeion del dis... ACTUALIZAR 


Figura 13. 5- Jerarquia en Tabla Dinamica 


Los campos de La jerarquia se pueden renombrar u ocuLtar de la 
vista del usuario, pero te recomendamos no hacer ninguna de estas 
dos acciones porque posiblemente te puedas confundir, lo que 
daria Lugar a ambiguedades dentro del modelo, sin embargo, al dar 
clic derecho sobre los campos de la jerarquia en la vista de 
diagrama, se presentaran dichas opciones. 

Medidas y Jerarquias 

Algo realmente util de crear una jerarquia es que podemos 
construir medidas utilizando los diferentes niveles de la misma, en 
el siguiente reporte puedes ver los ingresos obtenidos en cada 
periodo, pero adicionalmente, hemos creado dos medidas que nos 
muestran el porcentaje en el que influye cada periodo con 
respecto al total del nivel anterior de la jerarquia. 
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Fecha Q Ingresos 

% del Total(Mes) % d 

el Total (Trimestre) 

+ 

_ 

— Tril 

$49,429,52 


27% 

Jan 

$13,508,96 

27% 

100% 

Feb 

$ 1 7.592,04 

36% 

100% 

Mar 

$18,328,51 

37% 

100% 

-Tri2 

$45,700,64 


25% 

Apr 

$14,726,52 

32% 

100% 

May 

$13,507,17 

30% 

100% 

Jun 

$ 1 7.466,96 

38% 

100 %| 

+ Tri3 

$41,992,30 


23% 

+ Tri4 

$43,557,78 


24% 


Figura 13. 6- Medidas y Jerarquias 


En este reporte podemos ver el porcentaje en el que influye cada 
mes, en los ingresos de cada trimestre y a su vez, los ingresos que 
aporta cada trimestre en los ingresos anuales, de esta forma, 
podemos comparar que meses y que trimestres han tenido mejores 
rendimientos a traves deltiempo, a continuacion, se muestran las 
medidas. 


[% del Total(Mes)] := 

IF (ISFILTERED ( TABLA_Pedidos[Fecha de Envio (mes)] ); 
[Ingresos] / 

(CALCULATE ([Ingresos]; 

ALL ( TABLA_Pedidos[Fecha de Envio (mes)])) 

) 

) 
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TABLA_Pedidos[% del Total(Trimestre)]:= 

IF ( 

ISFILTERED ( TABLA_Pedidos[Fecha de Envio (trimestre)] ); 

[Ingresos] 

/ ( CALCULATE ([Ingresos]; ALL (TABLA_Pedidos[Fecha de Envio (trimestre)])))) 


Las medidas calculan el % del total respecto al nivel de la 
jerarquia, para este ejemplo el porcentaje de ingresos que aportan 
los meses al total de cada trimestre y asi mismo, el porcentaje de 
ingresos que aportan los trimestres a cada ano, dependiendo si la 
tabla es filtrada por trimestre o por mes, se calcula el % de 
ingresos, dividiendo los ingresos para ese item, sobre el total de 
los ingresos. Para entender la naturaleza de la medida, hagamos 
una breve pausa para hablar de ISFI LTERED. 


La funcion ISFI LTERED retorna verdadero cuando el ColumnName 
esta siendo filtrado directamente, si, por el contrario, no existe 
ningun filtro o se esta filtrando otra columna de la misma tabla o 
una tabla relacionada esta siendo filtrada entonces la funcion 
retorna Falso. 


Funcion 

ISFILTERED 

Definicion 



ISFILTERED(<columnName>) 


Argumentos Funcion ISFILTERED 

Argumento 

Description 

ColumName 

Nombre de una Columna Existente, no se 
puede utilizar otra expresion 


Sintaxis 


Argumentos 
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Con la funcion ISFILTERED en las dos medidas, evitamos realizar 
calculos innecesarios para que no sean mostrados en la tabla 
dinamica. aunque combinar medidas y jerarquias resulta muy util 
debemos tener en cuenta algunas consideraciones. 

El anterior reporte se puede crear a traves de las funcionalidades 
comunes de tablas dinamicas, mas exactamente con la opcion 
Mostrar Valores Como en la Configuracion de Campos, sin embargo, 
para duplicar el calculo en otro reporte, debemos repetir el 
procedimiento en cada tabla dinamica que queramos mostrar dicho 
calculo, a diferencia de Power Pivot, que solo se debe arrastra la 
medida al area de valores. 


Un punto a favor del metodo tradicional es que si cambiamos la 
jerarquia, el calculo seguira realizandose sin ningun problema, por 
el contrario, de la medida en el lenguaje DAX que no funcionara si 
se modifica la jerarquia, lamentablemente no podemos crear 
medidas genericas para ser usadas en cualquier jerarquia, puesto 
que es imposible conocer la configuracion que tendra la tabla 
dinamica, en consecuencia, elegir el metodo de calculo depende 
exclusivamente de las necesidades y requerimientos del reporte. 


Jerarquia Padre/Hijo 


Definicion 


Existen dos tipos de jerarquias, las estandar y las de relacion 
Padre/Hijo, la jerarquia creada en el anterior ejemplo, la podemos 
clasificar en la categoria de jerarquia estandar, a continuacion, se 
muestran una jerarquia de tipo Padre/Hijo. 
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Figura 13. 7- Jerarquia Padre/Hijo 


Las jerarquias padres/Hijo tiene las siguientes caracteristicas: 

■ El numero de niveles en la jerarquia no siempre es el mismo. 

■ Normalmente se almacena la jerarquia en una tabla, 
asignando en cada fila, la relacion que existe entre Padre e 
Hijo. 

Ahora, vamos a construir un reporte con una jerarquia Padre/Hijo, 
no obstante, debemos tener en cuenta que en Power Pivot no 
podemos crear jerarquias de este tipo y por eso debemos utilizar 
columnas calculadas y otras medidas adicionales asi que 
empecemos la creacion de nuestro reporte. 

El primer paso, es indicar en una tabla estructurada las diferentes 
conexiones que existen entre los elementos que contiene la 
jerarquia, luego de crear la tabla, debemos agregarla al modelo de 
datos. En la siguiente figura se muestra la tabla con las conexiones 
existentes. 
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ID g IMombre Vendedor g Conexion Padre IDg 


1 Ana 

2 Felipe I 

3 Alex I 

4 Julieta I 

6 Angelica 4 

7 Fernando 4 

d 


Figura 13. 8- Conexion Equipo de Vendedores 

Para este ejemplo, crearemos un reporte que muestre Los ingresos 
obtenidos por un equipo de vendedores, en la tabla, podemos ver 
facilmente las conexiones existentes de la jerarquia, el problema 
con este modelo es que Power Pivot no permite crear relaciones 
entre columnas de la misma tabla, y como ya lo dijimos, tampoco es 
posible crear jerarquias Padre/Hijo, en consecuencia, debemos 
reestructurar nuestro modelo convirtiendo la jerarquia Padre/Hijo 
en una estandar. En la siguiente tabla se muestran los ingresos 
obtenidos por cada Vendedor, no olvides agregarla al modelo de 
datos. 



Figura 13. 9~ Ingresos obtenidos por cada vendedor 


Para construir nuestro reporte, vamos a crear una columna 
calculada que muestre la conexion entre los vendedores, para 
posteriormente crear los diferentes niveles de la jerarquia. 





















El ADN DE Power Pivot 



A pesar de no poder crear jerarquias de este tipo, Power Pivot tiene 
un set de funciones disenado precisamente para manejar 
jerarquias Padre/Hijo, asi que hablemos un poco sobre La funcion 
PATH. 


La funcion PATH retorna una cadena de texto con Las conexiones 
existentes para La fiLa actuaL, es decir, muestra La relacion 
Padre/Hijo que hay entre Los eLementos de La tabLa. 


Funcion 

PATH 

Definicion 


PATH(<ID_columnNanne>, <parent_coLumnName>) 


Sintaxis 



Argumentos Funcion ISFILTERED 


Argumentos 


Argumento Descripcion 

ID_ColumnName Nombre de una columna existente y que 

contiene un unico identificador, no puede 
ser una expresion, 

Parent_ColumnName Nombre de una columna existente que 

contiene el identificador exclusivo para el 
padre de la fila actual 

Teniendo lo anterior en cuenta, vamos a crear una coLumna 
caLculada con La siguiente expresion. 


PATH (Jerarquia_Vendedores[ID]; Jerarquia_Vendedores[Conexion 
Padre ID]) 


Esta columna calculada unicamente es construida como paso 
intermedio para obtener Los demas niveles de la jerarquia. 
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Funcion 

LOOKUPVALUE 

Definicion 


Sintaxis 


Argumentos 



[Conexion] X v' jk =PATH(Jerarquia Vendedore5[ID];Jerarquia Vendedore5[Conexi6r 


ID Hi Nombre Vendedor Q 

Conexion Padre ID D 

Conexion ¥ 

Agregar columna 

□ 

1 Ana 


1 



2 Felipe 

1 

1 j 2 



3 Alex 

i 

1|3 



4 Julieta 

1 

1 1 4 



6 Angelica 

4 

1|4|6 



7 Fernando 

4 

1|4|7 


1 



Figura 13.10- Nuevo Columno Colculodo 


El siguiente paso consiste en construir tres columnas calculadas 
uno por cada nivel de la jerarquia, si existieran mas niveles, 
necesariamente deberiamos agregar mas columnas calculadas, 
pero primero entendamos el siguiente par de funciones que seran 
de gran ayuda. 

La funcion LOOKUPVALUE, retorna el valor de la columna 
especificada en el argumento Result_ColumnName, para la fila, 
teniendo en cuenta que se cumplan los criterios especificados en 
los demas argumentos, si no se satisfacen los criterios de busqueda, 
devuelve un valor en bianco. 

LOOKUPVALUE( <result_columnName>; <search_columnName>; 
<search_value>[; <search_columnName>; <search_value>]...) 



Argumentos Funcion LOOKUPVALUE 



Argumento 

Descripcion 

Result_ColumName 

Nombre de una columna existente que 
contiene el valor que deseamos retornar 

Search_ColumnName 

Nombre de una columna existente, sobre la 
cual se realizara la consulta 

Search Value 

Una expresion escalar, que no se refiere a 
cualquier columna de la misma tabla en la 
que se realiza la busqueda 


~ _ t5fe 

f WmJ! 
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Retorna un elemento en La posicion especificada por nosotros, de 
una cadena de texto resultante a partir de la funcion PATH, las 
posiciones se cuentan de izquierda a derecha 


Funcion 
PATH ITEM 
Definicion 


PATHITEM(<path>, <position>[, <type>]) 


Argumentos Funcion PATHITEM 

Argumento 

Description 

Path 

Una cadena de texto con la estructura del 
resultado arrojado por la funcion PATH 

Position 

Un numero entero, que representa la 
posicion del valor que deseamos retornar 

Type 

Un valor que define el tipo de dato a 


retornar. 


Sintaxis 


Argumentos 


Teniendo lo anterior en cuenta, creemos los diferentes niveles 
utilizando las siguientes medidas: 

Nivel 1= 

LOOKUPVALUE ( 

Jerarquia_Vendedores[Nombre Vendedor]; 
Jerarquia_Vendedores[ID]; PATHITEM ( 

Jerarquia_Vendedores[Conexion]; 1; 1) 

) 


Nivel 2 = 

LOOKUPVALUE ( 

Jerarquia_Vendedores[Nombre Vendedor]; 
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Jerarquia_Vendedores[ID]; PATHITEM ( 

Jerarquia_Vendedores[Conexion]; 2; 1) 

) 

Nivel3= 

LOOKUPVALUE ( 

Jerarquia_Vendedores[Nombre Vendedor]; 
Jerarquia_Vendedores[ID]; PATHITEM ( 

Jerarquia_Vendedores[Conexion]; 3; 1) 

) 

Ahora nuestra tabLa en el modelo de datos debe lucir de la siguiente 
manera: 


ID D 

Nombre Vendedor D 

Conexion Padre ID Q Conexibn Q Nivel 1 Q 

Nivel 2 Q 

Nivel 3 Q 

1 

Ana 


1 

Ana 



2 

Felipe 

1 

1|2 

Ana 

Felipe 


3 

Alex 

1 

i|3 

Ana 

Alex 


4 

Julie ta 

1 

1 1 4 

Ana 

Juliefa 


6 

Angelica 

4 

1|4|6 

Ana 

Julieta 

Angelica 

7 

Fernando 

4 

1|4|7 

Ana 

Julieta 

Fernando 


Figura 13.11- Columnas Calculadas paro coda Nivel 


Como puedes ver, existen campos vacios en algunos niveles, 
puesto que no hay relacion existente en dicho nivel, si crearamos 
el reporte inmediatamente, habria ciertos problemas de formato en 
la tabla dinamica porque esos campos en bianco serian visibles. 
Para resolver este problema vamos a optimizar las columnas 
calculadas en cada nivel agregando la funcion PATHLENGTH. 


Funcion 

PATHLENGTH 

Definicion 



La funcion PATHLENGTH retorna el numero de padres que contiene 
el elemento especificado en la fila, incluyendo el mismo elemento, 
en otras palabras, calcula el numero de niveles que tiene la 
jerarquia. 


ili'5 Eife 
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PATHLENGTH(<path>) 


Argumentos Funcion PATHLENGTH 

Argumento 

Description 

Path 

Una cadena de texto con la estructura del 
resultado arrojado por la funcion PATH 


Ahora bien, las expresiones de las columnas calculadas del 
segundo y tercer nivel quedarian la siguiente manera: 

Nivel 2 = 

IF ( 

PATHLENGTH (Jerarquia_Vendedores[Conexi6n]) >= 2; 
LOOKUPVALUE ( 

Jerarquia_Vendedores[Nombre Vendedor]; 
Jerarquia_Vendedores[ID]; PATHITEM ( 

Jerarquia_Vendedores[Conexion]; 2; 1) 

); 

Jerarquia_Vendedores[Nivel 1] 

) 

Nivel 3= 

IF ( 

PATHLENGTH (Jerarquia_Vendedores[Conexi6n]) >= 3; 
LOOKUPVALUE ( 

Jerarquia_Vendedores[Nombre Vendedor]; 
Jerarquia_Vendedores[ID]; PATHITEM ( 

Jerarquia_Vendedores[Conexion]; 3; 1) 

); 




Sintaxis 


Argumentos 


NOTA 

No es necesario re calcular 
el primer nivel porque 
todas las filas contienen 
un nivel. 
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Jerarquia_Vendedores[Nivel 2] 

) 


Con las medidas actualizadas, vamos a relacionar la tabla 
Jerarquia_Vendedores con la tabla de desempeno a traves de la 
columna ID. 



Figura 13.12- Relation entre Tablas 


Ahora, creamos una jerarquia estandar, con los tres niveles que 
hemos creado a partir de las columnas calculadas. 



Figura 13.13- Creation de Jerarquia. 


Para finalizar, vamos a crear un reporte de tabla dinamica, 
agregando en el area de filas la jerarquia que hemos creado, y en 
el area de valores, ahadimos una medida que calcule los ingresos 
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Equipo Vendedores 

lngre505_Vendedor 

B Ana 

28.800 

— Alex 

1.000 

Alex 

1.000 

— Ana 

3.000 

Ana 

3.000 

— Felipe 

4.000 

Felipe 

4.000 

— Julieta 

20.800 

Angelica 

800 

Fernando 

13.000 

Julieta 

7.000 

Total general 

28.800 


Figura 13. 14- Reporte con Jerorquio padre/Hijo 


Con el reporte finalizado, podemos observar como se muestran los 
ingresos obtenidos por cada miembro del equipo de vendedores, 
adicionalmente, podemos ver el total de ingresos obtenidos en 
cada nivel, con esto damos por finalizado, la tematica de jerarquias, 
no olvides que su uso es muy importante para facilitar busquedas 
y su implementacion depende exclusivamente del objetivo y las 
necesidades del reporte, bueno, ahora abramos paso a otra 
maravillosa funcionalidad de Power Pivot que al igual que las 
jerarquias, esta enfocada completamente en enriquecer el modelo 
y hacer reportes mas intuitivos, asi que bienvenido al mundo de los 
KPIs. 
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Indicadores 


Definicion 



KPIs: Key Performance Indicators 

Ahora, es momento de presentarte una de Las funcionaLidades mas 
potentes de Power Pivot, porque nos brinda la posibilidad de 
evaluar un indicador con respecto a una meta establecida por 
nosotros mismos, y, en consecuencia, entender si la estrategia de 
negocio es efectiva o no, todo apoyado en elementos visuales que 
facilitan la lectura por parte del usuario final. 

Entendiendo los KPIs 

Para entender mejor la funcionalidad de KPIs, hablemos un poco 
sobre indicadores, un indicador representa en un momento 
determinado el desempeno de un proceso o actividad dentro de la 
compania, para que sea monitoreado y con base en el estado actual 
del indicador, decidir si la meta se esta logrando o no. En esencia, 
podemos recrear este metodo de analisis de informacion a traves 
de las medidas que nosotros definamos en Power Pivot, 
combinadas con las funcionaLidades de KPIs. 

Funcionalidad KPIs en Power Pivot 

Un KPI es una representacion grafica de la relacion que existe y que 
podemos definir a traves del modelo de datos, entre una medida y 
un valor fijo, o incluso otra medida establecida, algunos de los 
beneficiosos de implementar esta herramienta en nuestros 
reportes son: 
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■ Alta capacidad de analisis de metricas e indicadores, a una 
velocidad de entendimiento extraordinaria. 

■ La posibilidad de crear reportes enfocados a analisis de 
estrategia de negocio. 

■ Reportes intuitivos y amigables con el usuario final. 

■ El uso de esta funcionalidad es simple y puede ser aplicado 
en cualquier escenario. 


Hagamos una breve pausa y observemos por un momento el 
siguiente reporte. 


Febrero 

Marzo 

Abril 

Mayo 

Junio 

Julio 

Agosto 

Septiembre 

Octubre 

Noviembre 

Diciembre 


P 2002 


Enero 

Febrero 

Marzo 

Abril 


10.540 
14.038 
12.965 

11.680 

15.337 

13.174 
11.437 

12.396 

10.443 

10.758 

12.213 


165.375 


14.812 

14.142 

14.076 

16.086 


16.059 
1 6,657 
13.208 

12.152 

1 5.623 
14.070 
13.279 
9.624 
13.008 
13.317 
12.429 


147.998 


13.015 

10.540 
14.038 
1 2.965 


-34% 

- 16 % 

- 2 % 

-4% 

- 2 % 

- 6 % 

- 14 % 

29% 

- 20 % 

- 19 % 

- 2 % 

14 % 

34% 

0 % 

24% 



Figura 15.15- Reporte de Utilidad del ono 2001 ol 2015 
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Como puedes ver, el reporte contiene muchos datos utiles para 
analizar relacionados con la utilidad y el crecimiento de la misma, 
sin embargo, debemos ser conscientes que extraer informacion y 
conclusiones sera una tarea dificil de lograr en poco tiempo. Para 
resolver dicho problema y crear un reporte mas robusto e intuitivo 
nos apoyaremos en la funcionalidad de KPIs, asi que primero, 
entendamos las medidas que contiene el reporte. 

Puede que la medida creada para calcular la utilidad no sea muy 
compleja, ni tampoco util, para analizar si el rendimiento de la 
empresa ha mejorado con el tiempo o no. Teniendo eso en cuenta, 
podemos calcular a traves del lenguaje DAX, el crecimiento de la 
utilidad ano a ano. 

Crecimiento Utilidad (%)= (Utilidad - Utilidad Ano Anterior) / (Utilidad 

Ano Anterior) 

Todo traducido al lenguaje DAX, queda de la siguiente manera, 
(recordemos que la medida Utilidad ($) se creo en el capitulo 11). 

Utilidad Ano Anterior := 

CALCULATE ( [Utilidad ($)]; SAMEPERIODLASTYEAR ( 
Calendario[Fecha])) 

Crecimiento Utilidad := 

([Utilidad ($)] - [Utilidad Ano Anterior]) 

/ [Utilidad Ano Anterior] 
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Con el indicador, % de crecimiento de la utilidad, podemos aplicar 
la funcionalidad de KPIs. Los KPIs utilizados en reportes se pueden 
aplicar en dos escenarios diferentes... 


Primer Escenario - Analisis de estado a traves de un valor fijo 

Es un metodo que permite comparar una medida o indicador 
definido por el usuario, con respecto a un valor fijo en forma de 
porcentaje (Algo asi como una regia o un metro). Adicionalmente, 
podemos agregar niveles de estado para que visualmente se 
transmita si es "bueno" o “malo" el estado en el que se encuentra 
el indicador, teniendo esto en mente construyamos el KPI. 


Para crear un KPI nos dirigimos a la pestana Power Pivot en Excel, 
y en el grupo Calculos, Damos Clic en el comando KPIs y elegimos 
la opcion Nuevo KPI. 


INICIO 


INSERTAR 


DISENO DEPAGINA 


FORMULAS 


DATOS 


REVISAR 


Administrar 

Modelo de dates 

B *>- c* 


[6 

Campos 

calculados T 

Calcuk 

KPIs 

g Alinear verticalmente 

Alinear horizontal mente 

Agregar a Actualizar 

modelo de datos todo 

Tablas 

% Nuevo KPI... 

intacion de dates. 

SP- SP- 

^ Administrar KPIs... 



Figura 13.16- Crear Nuevo KPI 


En el cuadro de dialogo Indicador Clave de Rendimiento (KPI) es 
donde la magia ocurre. Como puedes ver en la figura 13.17, 
debemos definir tres elementos importantes: 


■ Campo Base de KPI: Es el indicador o medida a la cual vamos a 
evaluar y comparar, principalmente, para entender en que 
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estado se encuentra, para este ejemplo, es la medida 
Crecimiento de Utilidad. Adicionalmente, ten en cuenta que 
el estado del indicador se mostrara graficamente en el 
reporte, a traves de un simbolo que representa el nivel en el 
que se encuentra. 

■ Definir Valor de Destino: en este sub grupo, debemos 
establecer el valor con el que va a ser contrastado el estado 
del indicador, para este ejemplo, Definimos la opcion valor 
Absoluto como 1, teniendo en cuenta que, 1 es igual a 100% 
, 2 a 200%, y asi sucesivamente, dado que la tasa de 
crecimiento de la utilidad es un porcentaje. 

■ Definir Umbrales de Estado: Como ya lo dijimos, el valor de 
destino representa una regia, entonces, los umbrales de 
estado son los niveles o estados en que el que el Indicador 
se clasificara y por ende su representacion grafica dentro del 
reporte tomara un color, para este ejemplo: vamos a definir 
como valores "Malos" los valores menores a 15%, valores 
"regulares", entre 15% y 50% y los mayores a 50% se 
clasificaran como "Buenos". 


jToma Nota! 



Los niveles que representan los umbrales son relativos y, por ende, 
definir cual nivel es "bueno" y cual “malo", depende exclusivamente 
de las necesidades y requerimiento establecidos en la creacidn del 
reporte. 
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Figura 13.17- Cuodro de Dialogo Indicodor Clove de Rendimiento KPI 


Para finalizar, presionamos el boton Aceptar y a continuacion en el panel de 
campos de la tabla dinamica, aparece una nueva carpeta con los elementos 
del KPI que hemos creado. 


Campos de tabla dinami... ^ x 

ACTIVO TODOS 


Seleccionar campos para agregar at 
informe: 



Lvg utilidad m 

Utilidad Ano Anterior [S] 

Crecimiento Utilidad 

Valor [Crecimiento Utilidad [%)) 

Objetivo 

O Estado 


0 


Figura 13.18- KPI en el Panel de Campos 
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Ahora, podemos arrastrar los campos del KPI al area de valores de 
La tabLa dinamica. 


■ Si arrastramos eL campo Valor al area de valores, en la tabla 
dinamica se mostrara como valor numerico el calculo o 
estado de esa medida, para este caso el % de crecimiento 
de la utilidad. 

■ Si llevamos el campo Objetivo al area de valores, se mostrara 
el valor objetivo que hemos definido. 

■ Si llevamos el Campo Estado al area de valores, se mostrara 
graficamente el estado del indicador, dependiendo de Los 
umbrales o niveles que definimos previamente. 



Enero 

Febrero 

Marzo 

Abril 

Mayo 

Junio 

Julio 

Agosto 

Septiermbre 

Octubre 

Noviembre 

Diciembre 


14.812 

14.142 

14.076 
16.086 
16.095 

13.491 

15.499 

13.140 

14.629 

12.780 

10.228 

10.398 


14 % 

34 % 

0 % 

24 % 

38 % 

- 12 % 

18% 

15% 

18% 

22 % 

- 5 % 

- 15 % 


EB 


100 % » 
ioo%o 
100% ® 
ioo%o 
ioo%o 
100% a 

I00%Q 
100% Q 
ioo%o 
ioo%Q 
100%® 
100%® 
IESH 


Figura 13■ 19- Reporte con KPIs 


Como se ve en esta pequena imagen de la tabla, podemos entender 
rapidamente que, en ningun mes del ano 2002, se obtuvo una tasa 
de crecimiento en las utilidades mayor al 50 %, y por ende no fue 
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un ano muy bueno. Pero no nos detengamos mucho en este ano, 
observemos un momento el ano 2015. 


o 

Enero 

28.564 

55% 

100% Q 

Febrero 

23.576 

24% 

ioc%o 

Marzo 

28.307 

58% 

IOO%Q 

Abril 

27.807 

40% 

ioo%o 

Mayo 

1 7.766 

-6% 

I00%Q 

Junio 

25.204 

42% 

100%® 

Julio 

31.713 

49% 

ioo%0 

AgQ5tO 

23436 

1 1% 

ioo% o 

Septieimbre 

23.224 

25% 

I00%Q 

Octubre 

23400 

17% 

I00%Q 

Noviembre 

26,912 

58% 

I00%Q 

Diciembre 

12.926 

-25% 

I0G%Q 


Figura 13. 20- Reporte con KPIs 


Como podemos ver, los simbolos no son del todo precisos, sin 
embargo, son muy utiles para transmitir informacion sobre el 
crecimiento de la utilidad en el ano 2015, por ejemplo, sigue 
siendo mayor el numero de meses con un % deficiente, ademas, 
seria apropiado, crear estrategias para aumentar el % de 
crecimiento de la utilidad en el mes de diciembre, puesto que no 
fue muy rentable a pesar de ser temporada de alto flujo de ventas 
para el mercado en general, entre otras muchas conclusiones que 
podemos obtener rapidamente. 


Segundo Escenario - Analisis Dinamico 


Hay ocasiones en que no es apropiado definir el valor de destino 
como absoluto, sino que debemos recurrir a medidas para crear 
una regia de comparacion que este acorde con el escenario, 
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para este ejemplo, vamos a analizar el crecimiento de la utilidad, 
con respecto al Promedio de la Tasa de crecimiento ano a aino. 
Teniendo esto en mente, creemos la medida que calcula el 
Promedio del crecimiento de la utilidad entre todos los anos. 

Promedio % Crecimiento Utilidad := 

CALCULATE ([Crecimiento Utilidad]; ALLSELECTED (); VALUES ( 
Calendario[Ano])) 

Ahora debemos agregar un KPI pero esta vez el valor absoluto sera 
la medida que recien hemos creado. 


Indicador clave de rendimiento (KPI) 



Estado de KPI 


□efi n i r el va lor de desti no: 



O Valor absoluto: 

□efinir umbrales de estado: 



□estino 


•nr © a x ♦ a .iii .<■ bh §□ o • 

O r • □ 1 A it ,;IJ .III me DO (3 • 

oj r • a ✓ o * riiii » 3 


Aceptar ~| Canedar 


Figura 13. 21- Configuration del Cuadro de Dialogo 
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Teniendo en cuenta si el indicador se encuentra 15% por debajo 
del promedio se calificara como malo, y si esta 15 % por encima 
del promedio se considerara bueno, en la anterior figura se observa 
como estan configurados los umbrales para que se cumpla dicha 
regia. Para hacer mas dinamico el reporte, vamos a agregar un slicer 
con el campo Pais de la tabla pedidos, para que podamos insertar 
un filtro dependiendo de la zona que deseemos analizar. 


Pafs 

Argentina 

a 

Brasil 

Chile 

Colombia 

Ecuador 

Paraguay 

Peru 

Uruguay 

V 


Ano 

□ 

Utilidad ($) Crecimiento Utilidad Estado Crecimiento Utilidad 

±g 




d 



■iezec 


Enero 

1481 2,0 

13, SO' % G 

Febrero 

14141,61 

34,17 % Q 


Marzo 

14075,8" 

0 , 17 % a 


Abril 

16086,0 

24,07 % G 


Mayo 

16094,7 

37,80' 


Junto 

13491J 

-12,04%# 


Julio 

15498,6 

17,64 % Q 


Agosto 

13140,4 

14,90' % G 


Septiembre 

14629,1 

18,01 %G 


Octubre 

12780,3 

22,38 %G 


Noviembre 

10228,1 

-4,93 % G 


Diciembre 

10397,5 

-14,87 %G 

Eg 



Eg 

eg 



Eg 


NOTA 

La funcionalidad de KPIs 
tambien es aplicable en 
Power View. 


Figura 13.22- Reporte Dinamico 


Con este reporte estaremos en capacidad de medir en que estado 
nos encontramos con respecto al promedio del crecimiento de la 
utilidad, adicionalmente, si seleccionamos algun elemento del 
slicer, los indicadores cambiaran automaticamente, jDinamita Pura! 


EL Siguiente Paso 


El siguiente capitulo estudiamos como crear el tipo de relacion 
muchos a muchos en Power Pivot que tenemos pendiente desde el 
capitulo cinco, ademas de como tratar con multiples tablas base. 
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DAX Como Lenguaje de Consulta 
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Introduccion 

En el desarrollado de todo el libro hemos utilizado DAX para el 
analisis de datos, es decir, para le creacion de formulas bien sea 
basicas o complejas para resumir datos y asi poder extraer 
informacion que puede ser valiosa para la compama. 

DAX, es un lenguaje poderoso para crear soluciones de inteligencia 
de negocios, su aplicabilidad precisa depende directamente del 
area especifica del lector: Inventario, Marketing, Finanzas, etc., etc. 
Por otra parte, el lenguaje DAX tambien puede ser utilizado como 
lenguaje de consulta. 

El presente capitulo es una breve introduccion a lenguaje DAX 
aplicado para hacer consultas a las tablas de Power Pivot. 


^Por Oue Utilizar DAX como Query? 

Poder contar con las tablas directamente en Excel nos da el 
beneficio de utilizar todas las funcionalidades de la hoja de calculo, 
lo cual en algunas ocasiones es mas comodo. 


Consultar datos, procesarlos en Excel y volverlos a enviar Power 
Pivot despues de un proceso, es la Have para realizar una cantidad 
inimaginable de analisis. 


Brinda la posibilidad entender como operan ciertas funciones detras 
de camaras y poder interiorizarlas de manera correcta, debido a que 
podemos observar su resultado directamente en una hoja de Excel. 
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m 


EVALUATE 


La funcion EVALUATE es quien nos permite hacer consultas en Las 
tablas de Power Pivot y ninguna otra. Por ejempLo: 


EVALUATE! 

FILTER! TABLA_Pedidos; 

TABLA_Pedidos[Categoria de Descuento] = "Non") 


El ejemplo traeria una tabla en Excel con solo aquellos registros 
que corresponde unicamente con la categoria Non. 

La funcion EVALUATE tiene un monton de argumentos, aqui 
solamente la vamos utilizar en su forma mas simple: 

EVALUATE(<tabla>) 


NOTA 

La funcion EVALUATE, es 
la funcion para hacer 
consultas, por ello, no se 
puede utilizar en ninguno 
de los tipos de calculo 
personalizados: Medidas 
o Columnas Calculadas, 
dado que retorna una 
tabla. Esta se debe 
empezar en el cuadro de 
dialogo edition de 
consulta. 


Donde el argumento <tabla> es cualquier expresion o funcion que 
por definicion retorne una tabla, tales como: FILTER, 
CALCULATETABLE, ALL, etc. 

Crear Consulta 

Para crear una consulta y verla en la hoja de calculo de Excel, 
debemos seguir dos pasos: 


1) Importar una Tabla de Power Pivot 

2) Editar Consulta 
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ImportarTabla 



Para importar una tabla de Power Pivot debemos ir a la pestana, 
DATOS, grupo OBTENER DATOS EXISTENTES y clic en el comando 
CONEXIONES EXISTENTES. 


Diseno de pagina Formulas Datos Revisar 


a 


R' 

S Mostrar consultas 
® [H Des.de una tabla 

:sde otras 

Conexiones 

Nueva 

jentes T 

existentes 

consults - L© Fuentes recientes 

:ernos 



Obtener y transformer 


II- 

Figura 14 .1 - Comando Conexiones Existentes 


Con lo anterior se despliega el cuadro de dialogo CONEXIONES 
EXISTENTES, en la seccion Conexiones en este libro, podemos 
apreciar las tablas que hemos conectado y agregado a Power Pivot 


Conexiones existentes 

Seleccionar una conexion o tabla 
Conexiones Tablas 


? X 


Mostrar: jodas las conexiones 


B 


Conexiones en este libro 


Access TABLAS Red id os Ease de Datos Relational 


Data Ma rketWeb Feed B oya n PenevDateStrea m 
[En bianco] 

Excel TAB LA_ Production 
[En bianco] 

Excel TABLA SKUProductos 
[En bianco] 

Text TAB LA_Categ o ria DeP rod uctos 
[En bianco] 

Archivos de conexion en la red 

< N o se enco ntra ro n co nexio nes > 

Archives de conexion en este equipo 

P Adventu reWo rks P rod uctio n_ P rod uctl nvento ry 
3 [En bianco] 


IS 

[In 

Hi 

fn, 


Examinar en busca de mas,. 


Figura 14.2 - Cuadro De Dialogo Conexiones Existentes 
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Seleccionamos cualquier tabla de la seccion y clic en el boton 


ABRIR, con lo cual surge un nuevo cuadro de dialogo: 


Importar datos ? X 

Seleccione como desea ver estos datos en el libro. 
0 ® Tabla 

[71 O Informs de tabla dinamica 
i'eS O Grafico dinamico 
[ 7 ] O Generar informes de Power View 
* O Crear solo conexion 
^Donde desea situar los datos? 

® Hoja de calculo existente: 


= SDS7| 


IS 


O Hoja de calculo nueva 

Agregar estos datos al Modelo de datos 


Propiedades... 



Aceptar 


Cancelar 


Figura 14. 3 - Cuodro de Dialogo Importar Datos 


Dejamos la opcion: Tabla, seleccionada, y decidimos donde 
queremos que aparezea la tabla, en una hoja nueva o a partir de una 
celda especifica en la hoja actual; posteriormente pulsar clic en el 
boton aceptar. Veremos la tabla importada. 


Dnefto de ptgir* Fdrmuta 


r ^ ,Cort * I Gil Sara MT -||2 * A* a' = 

IfeCopi., • ' 

+^<0^0 a- - 


Rcmar VsU Osanolladar Q flu* dee* haca 


9 /' Ajustar teno 
DO § Combm* y centra. 


| Calculo 


© 


51 Rellenor • 


9 Bon». • 



• £r P 

Q'dfnei y Bukw y 


u 



22 

23 

2* 

25 

26 

27 

28 
2* 

30 

31 




■ HII. 1 IUI 1 H 1 JJIJI - 


l«l 1/2017 Un**, Homdao 
5*7015 Cano* 

7*7015 Urv**, 

2*7015 Ch* 

27/7/2015 8 n* 

6/3.7018 Paraguay Atone** 

16/7/2015 CM. Vfedalttar 

8/11/20(7 fWu lm 
8/7/2015 Ecuador Quito 
8*70(5 Ur up-ay I 



Figura 14. 4 - Tabla Pedidos Importada a Excel 
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Editar Consulta Editar la consulta es bien sencillo, solamente dejamos la celda 

activa dentro de la tabla recien importada y pulsamos CLIC 
DERECHO, con lo cual se despliega un menu contextual, alii 
ubicamos las opciones de TABLA y en los comandos que aparecen 
pulsamos en EDITAR DAX. 


B 

Gill Sans - 12 ' r A* A~ $ ”' % 

000 || f G H 1 


N K = & ' A * tH 4$ 




980694 HI Normal 

IrOAl 61 — 

Cortar 

222 03 1 636 

98069420 Normal 

22103 1 515 

98069428 Normal 

Hj=) Copiar 

22103 1 8.99 

98069437 Normal 

(|q Opciones de pegado: 

® 1 ! 

Pegado especial... 

P Busqueda inteligente 

22103 1 7.84 

98069512 Normal 

22103 1 8 

98069540 Normal 

22103 022 

98069591 Normal 

22103 1 7J2 

98069607 Normal 

22103 1 735 

98069683 Normal 

22103 1 9 

98069710 Normal 

Actualizar 

insertar ► 

22103 \ 9.61 

98069831 Normal 

22103 1 9.99 

98069854 Normal 

22103 1 6.99 

98070133 Normal 

Eliminar ► 

22103 1 9.61 

98070 S7 Normal 

Seleccionar ► 

Borrar contenido 

22103 i 5.99 

98070261 Normal 

22103 1 5.61 

90070265 Normal 

22103 1 938 

98070270 Normal 

,^1 Analisis rapido 

22103 1 9 

98070295 Normal 

Ordenar ► 

22103 1 7.45 

98070344 Normal 

22103 1 6.75 

98070351 Normal 

Filtrar ► 

22103 1 9.36 

98070360 Normal 1 

Tabla ► 

kM Fila detotales 661 

98070370 Normal 

V-l Insertar comentario 

9 835 

98070373 Normal 

Convertir en rango ■ 784 

98070491 Normal 

[HI Formato de celdas... 

[H] Propiedades de los datos externos... 8.86 

98070527 Normal 

Elegir de la lista desplegable... 

Hipervmculo... 

Modificar consulta... 

98070530 Normal 

f ' “ \ 8.9 

98070738 Normal 

\m Editar DAX... J ^2 

98070959 Normal CB0I Non 

5.33 

98071131 Normal CBOI Non 

Desvincular de origen de datos ^_ 

90071152 Normal CBOI Non 

8.36 

98071159 Normal C80I Non 

Texto alternativo... [ 714 

9807 20 Ncrr’il CEO Non 

22103 935 
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■377 iw 
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Figura 14. 5 - Editor DAX 


Ahora se despliega un nuevo cuadro de dialogo con nombre editar 
DAX, alii es donde haremos la edicion, las consultas DAX para una 
tabla de Power Pivot 
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EditarDAX 


X 


Usa el Lenguaje de expresiones de analisis de datos (DAX) para modificar los 
resultados que devuelve la conexion al modelo de datos del libro. 

Seleccione el tipo de comando DAX e introduzca una expresior 


lipode comando: |tabVa"j ^ 


Expresion: 


TABLA Pedidos 


Aqui debemos, desplegar las 
opciones y seleccionar DAX 
para poder hacer las 
consultas. 


Caja de texto para emplear 
expresiones DAX encerradas 
en EVALUATE para retornar 
Tablas. 


Figura 14. 6 - Cuodro de Didlogo Editor DAX 


Aqui podemos pegar La consuLta del ejempLo mostrado aL principio 


EditarDAX 

Usa el Lenguaje de expresiones de analisis de datos (DAX) para modificar los 
resultados que devuelve la conexion al modelo de datos del libro. 

Seleccione el tipo de comando DAX e introduzca una expresion: 

Tipo de comando: 


X 


DAX 


Expresion: 


EVALUATE ( 

FILTER! TABLA.Pe didos, 

TABLA_Pedidos[Categon'a de Descuento]='Non D )) 






Aceptar 


Cancelar 





Figura 14. 7 - Primero Consulta 
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jToma Nota! 



Sin importar la configuracion del separador lista de tu computadora, 
bien sea coma o punto y coma (o cualquier otro) el separador de 
argumentos en las expresiones DAX escritas en el cuadro de dialogo 
editor DAX siempre se separan por coma (,). 


CALCULATETABLE 

Recordemos de capitulos previos que La funcion CALCULATETABLE 
retorna una tabLa, la cual La hace ideal y potente para consultas. 

Por ejemplo, si queremos extraer una porcion de La tabLa Pedidos 
pero basada en un filtro de una tabLa de busqueda, lo podemos 
hacer sin ningun problema, en especifico: 


EVALUATE! 

CALCULATETABLE! 

TABLA_Pedidos, 

Calendario[Mes Nombre] = "Enero" 

)) 


Nota que se esta filtrando La tabLa Pedidos de acuerdo a una tabLa de 
busqueda, en este caso la tabla de Calendario, esto se ejecuta sin 
ningun inconveniente retornando La tabla deseada (solo el mes de 
enero). 
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ADDCOLUMNS 

La funcion ADDCOLUMNS nunca La hemos tratado en el texto, pues 
es especialmente util para consultas. 

La funcion ADDCOLUMNS es un iterador, asi como FILTER, retorna Definicion 

una tabla especificada en su primer argumento, enriquecida o 
expandida con un nuevo conjunta de columnas. 

ADDCOLUMNS(<tabla>;<nombre>;<expresion>;...) Sintaxis 

La funcion ADDCOLUMNS tiene un numero indefinido de 
argumentos o parametros: 

^ Argumentos de la Funcion ADDCOLUMNS Argumentos 


Argumento 

Descripcion 

Tabla 

La tabla que queremos expandida 

Nombre 

Nombre de la nueva columna entre comillas dobles 

Expresion 

Expresion que devuelva une escalar para crear la 
columna. 


Ejemplo: 

EVALUATE! 

ADDCOLUMNS (’TABLA_CategoriaDeProductos', "Numero de Productos", 
CALCULATE(COUNTROWS(TABLA_Pedidos))) 





) 
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Un vistazo a La imagen: 


NOTA 

Se pueden seguir 
anadiendo columnas, 
cuantas necesitemos, 
solamente debemos 
seguir indicando tanto el 
nombre como la 
expresion despues del 
tercer argumento. 


5KU Precio de Vent a Categona [ 

Niimere de Productos J :j 

LOI 30.75 Libra 

11945 

L02 40.2 Libre 

240B ■ 

103 29.99 Libre 

L 469 

L04 30.1 Libra 

993 

LOS 4:155 Libra 

1! 956 

L06 4L55 Libra 

729 

L07 37.S9 Libra 

1535 

LOB 50.99 Libra 


DOB 25 DVD 


D02 20 DVD 


D03 60 DVD 


D'04 IB DVD 

L J 


Figura 14. 8 - Porcion del Resultado del Query con ADDCOLUMNS 


SUMMARIZE 

Definicion La funcion SUMMARIZE retorna una tabLa de resumen sobre un 

conjunto de grupos. 

Sintaxis SUMMARIZE(<tabLa>; <grupo>;...;[<nombre>];[<expresion>]) 


La funcion SUMMARIZE es una de las funciones mas utiles y 
utilizadas para consultas en Power Pivot, se pueden hacer cosas 
sencillas como otras de mayor envergadura. 



> Argumentos de la Funcion SUMMARIZE 

Description 

Argumento 

Table 

Una expresion DAX que retorne una tabla. 

Columna 

Una columna existente utilizada para crear grupo. 

Nombre 

Nombre para el total o columna de resumen. 

Columna 

Una expresion DAX que devuelva un escalar. 
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Veamos un ejemplo y sus resultados, sabemos que de esta manera 
sera mas claro. 


EVALUATE! 

SUMMARIZE ( TABLA_Pedidos, TABLA_Pedidos[SKU])) 


Retorna: 


A D 




U 


2 

3 

4 

5 

6 
7 

s 

9 

10 

11 

12 

13 

14 

15 

16 

17 

18 
19 

io 

?i 

12 

B 

14 


SKU 

CCOI 

L02 

CBOI 

C 12 

IL07 

ILOI 

BOS 

802 

L04 

CC02 

LOS 

L03 

BO* 

BO I 

C13 

L06 

CM 

CIO 

B04 

C14 

B03 


Tabla 14. 3 - Ejemplo 1 SUMMARIZE elementos unicos 


Devolvio todos los elementos unicos del campo SKU en la tabla 
Pedidos, no obstante, si ese fuera el fin de la historia no serfa del 
todo potente; como se puede observar en la sintaxis despues del 
argumento grupo hay puntos suspensivos, quiere decir que 
podemos anadir mas grupos (columnas) observemos que sucede. 


M m 


T L 
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EVALUATE! 

SUMMARIZE! 

TABLA_Pedidos, 
TABLA_Pedidos[SKU], 
TABLA_Pedidos[Tipo de Compra] 
)) 


Retorna: 



A 

8 

C 

1 



2 


5KU Tipo de Compra 

3 


CCOI 

Normal 

4 


CCOI 

Devoludon 

5 


L02 

Noinmal 

6 


IL02 

Devoludon 

7 


CBOI 

Normal 

8 


C BO 1 

Devoludon 

9 


CI2 

Normal 

10 


CI2 

Devoludon 

II 


LOT 

Normal 

12 


L07 

Devoludon 

13 


LOI 

Normal 

114 


LOI 

Devoludon 

15 


B05 

Normal 

16 


805 

Devoludon 

7 


802 

Normal 

IB 


802 

Devoludon 

19 


104 

Normal 

20 


L04 

Devoludon 

21 


CC02 

Normal 

22 


CC02 

Devolution 

23 


L05 

Normal 

24 


L05 

Devoludon 

25 


L03 

Normal 

26 


L03 

Devoludon 

27 


806 

Normal 

28 


806 

Devoludon 

29 


801 

Normal 

30 


801 

Devoludon 

31 


CI3 

Normal 

32 


CI3 

Devoludon 

33 


106 

Normal 

34 


L06 

Devoludon 

35 


CM 

Normal 

36 


CM 

Devoludon 

37 


CIO 

Normal 

38 | 


CIO 

Devoludon 

39 


804 

Normal 

40 


804 

Devoludon 

41 


CI4 

Normal 


Figura 14. 9 - Segundo Ejemplo con SUMMARIZE 















































El ADN DE Power Pivot 



Con lo anterior se puede ver un poco mas el potencial de la funcion 
SUMMARIZE, vemos que ahora devuelve los elementos de ambas 
columnas que son comunes a ambos, sin embargo, si tomas las filas 
completas, veremos que estas no se repiten. 


Pausemos un Momento 



Fijate en como los dos ejemplos de la funcion SUMMARIZE previos 
pueden ser especialmente utiles cuando queremos construir la tabla 
de filtros intermedia y la tabla de conexion para realizar una relacion 
muchos a muchos como estudiamos en el capttulo 12. 


En la sintaxis de la funcion SUMMARIZE vemos que los ultimos 
argumentos son opcionales, estos hacen lo mismo que 
ADDCOLUMNS, indicamos un nombre y una expresion para 
expandir la tabla, por ejemplo: 


EVALUATE! 

SUMMARIZE! 

TABLA_Pedidos, 

TABLA_Pedidos[SKU], 

TABLA_Pedidos[Tipo de Compra], 

"Ingreso con Impuesto", 

SUM (TABLA_Pedidos[Precio de Venta]) * 0.16 

) 

) 







Capitulo 14 / DAX Como Lenguaje de Consulta 


SKU Tipo de Cornpra Ingreso co 

n 1 mpuesto [ 

CCOI 

Normal 

42083.25384 

CCOI 

□evolucldn 

SI4L99045 

L02 

Normal 

22899.2064 

102 

D evolution 

4591.8048 

CB01 

Normal 

247856-5296 

CB01 

□evolution 

53887.56912 

C 12 

Normal 

1917.39904 

C 12 

□evolution 

285.03168 

L07 

Normal 

13647.978 

107 

□evolution 

2882.06496 

LO 1 

Normal 

13876.368 

LOI 

□evolution 

3148.308 

B05 

Normal 

3145.9728 


Figura 14 .10 - Ejemplo 3 con SUMMARIZE 

Hay un buen grupo de funciones para consultas, como: ROOLLUP, 
GROUPBY, TOPN, RANK, GENERATE, etc. Pero tenemos la seguridad 
que en el momento que las necesitas podras consultar sus sintaxis 
en el MSDN y podras aprender en un santiamen. 


Por lo que damos por finalizado este capitulo y el libro. 


lOuieres mas contenido? Y continuar este maravilloso viaje por 
Microsoft Bl. Tenemos algo que tepuede interesar. 


■ El ADN de Power View: 


Referenda Cruzada 



LIBRO: EL ADN de Power View - Miguel Caballero & Fabian Torres. Es 

vital poder transmitir la information obtenida de manera efectiva, y nada 
mej'or que los graficos y las representaciones visuales, Power View es un 
complemento que permite tomar las medidas de Power Pivot y mostrarlas 
en graficos como un dashboard, el ADN de Power View explora, estudia y 
profundiza en Power Viewy Visualization de Datos. 




































El ADN DE Power Pivot 



■ El ADN de Power Bl (.com) & Desktop. 


Referenda Cruzada 



LIBRO: EL ADN de Power Bl (.com) y Desktop - Miguel Caballero & Fabian 
Torres. Power Bl es lo que te recomendamos de corazon, como tu proximo 
parada. En esta herramienta tenemos el lenguaje DAX, visualizacion de 
datos al cubo y otras cosas super utiles, en el asumimos que ya has 
pasado por este libro, por lo que se enfoca en visualizacion y aplicaciones 
de Bl con DAX + Comunicacion de Datos Efectiva. 


Comentarios Finales 

Mi amigo@ eso ha sido todo, ha sido un viaje largo y en sus 
momentos complejo, pero divertidisimos 1 N 0 crees?, nosotros 
escribiendo una y cada una de las lineas de este texto no 
dejabamos de sonreir por el hecho de compartir contigo todo este 
bonito material, esperamos la hallas pasado super en el desarrollo. 

Power Pivot es una herramienta poderosisima, sin embargo, 
recuerda que el poder esta en las personas y lo que puedas hacer 
con este armamento futurista en tu arsenal, no queremos finalizar 
sin antes decirte: que sigas practicando, experimentado y por 
encima de todo aplicando; sacale el maximo provecho jMantente 
curioso! Y emprende nuevos caminos a otras tecnologias Bl. 

jUn Fuertey Calido abrazo !, tus amigos: 

- Miguel Caballero 

- Fabian Torres 










La Presente Pagina se ha dejado en Blanco de forma deliberada. 




Anexos 
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nexo 



Glosario de Terminos: Para Consulta Rapida 


Introduccion 


En este anexo puedes encontrar los terminos, conceptos claves y cri'ticos que todo crack 
del lenguaje DAX y creador de modelos de datos debe conocer, y sobre todo entender 
con la mayor claridad y maestria del mundo, en realidad hay algunos conceptos propios 
de este texto pero que no dejan de ser vitales; con esto el fin ultimo es que en el proceso 
de aprendizaje puedas consultar algun concepto de forma rapida para asi' repasar y avanzar 
con mayor facilidad a lo largo del libro. Este anexo tiene tres o mas conceptos de cada 
capi'tulo, por lo que en el proceso de aprendizaje, practica y experimentation no los 
entenderas todos, pero una vez finalizado este libro seran supremamente sencillos de 
entender. 


* Aka: Tambien Conocido Como (Also Know As) 
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Azure Marketplace 

Aka: Microsoft Azure Marketplace 


Es un mercado On-line que nos permite comprar y vender software como servicios (SaaS) es decir crear 
programas, alojarlos y mantenerlos en la nube y proveerlos a un cliente; ademas Azure Marketplace es un 
mercado de datos en linea global, donde podemos comprar bases de datos, imagenes, datos comerciales y datos 
publicos acreditados. 


Calendario Estandar 

Aka: Standard Calendar 


Es el calendario en el cual el mes de febrero tiene 28 dias o 29 dias en anos bisiestos, mientras que el resto de 
meses tienen 30 o 3 I dias, por lo tanto, el ano tiene 365 dias o 366 dias. Es decir, el calendario estandar el 
gregoriano, aquel que tenemos en nuestro celular y utilizamos dia a dia. 


Calendario Personalizado 

Aka: Custom Calendar 


El calendario personalizado es un tipo de calendario ajustado a las necesidades de la empresa o persona con 
motivo de su ejercicio laboral, por ejemplo: los semestres academicos, las temporadas deportivas, ciclo de 
proveedores, etc. Etc. 

Clave Principal 

Aka: Primary Key / Clave Primaria 


Columna de una tabla donde no se repite ningun item o elemento, por lo tanto, identifica de forma unica cada 
fila de la tabla, es utilizada para crear relaciones. 

Clave Externa 

Aka: Foreign Key / Primary Foranea / Clave Ajena 


Columna de una tabla base donde se repiten los elementos a lo largo de la columna, esta identifica un grupo de 
columnas en la tabla de busqueda, se utiliza para relacionar con otra tabla que contenga la clave principal. 


Contexto 

Aka: Context 


Conjunto de filas y columnas restantes despues de aplicar uno o mas filtros y/o restricciones en las diferentes 
tablas, donde se evaluara una expresion (formula). 
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Contexto de Consults 

Aka: Query Context 


Es el contexto (conjunto de filas y columnas) que quedan despues de aplicar los filtros que derivan directamente 
del reporte de tabla dinamica, es decir, los filtros generados por al area de colocacion y slicers, puedes pensarlo 
con el primer contexto puro antes de ser alterado por cualquier restriccion. 

Contexto de Evaluation 

Aka: Evaluation Context 


Es el escenario completo y final donde se evalua una formula, se compone por el contexto de filtro que brinda 
la tabla para su ejecucion y el contexto de fila que permite determinar el calculo fila a fila. 

Contexto de Fila 

Aka: Row Context 


Es la fila actual en la tabla de Power Pivot, en cuyo caso se evalua una expresion, visto de otro modo, el contexto 
de fila proporciona el grado de especificacion para que se ejecuten las funciones de agregacion. 

Contexto de Filtro 

Aka: Row Context 


Es el contexto que (conjunto de filas y columnas restantes) surge despues de aplicar las restricciones que alteran al 
contexto de consulta. 


Coordenada 

Aka: Filtro Virtual / Referenda 


Es la especificacion de un filtro que se va aplicar a una tabla, por ejemplo: Pais=”Co/omb/o”, pero que aun no se 
ha aplicado, se puede pensar como el filtro virtual que se convertira en filtro una vez se aplica a la tabla. 


DAX 


Aka: Data Analysis Expressions 


Son las siglas para: Data Analysis Expressions, que se puede traducir al espanol de forma aproximada como: 
Expresiones para Analisis de Datos. 
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Entretejido de Tablas 

Aka: Sistema de Relacion de Tablas • Termino Propio 


Es la configuracion de relaciones entre las diversas tablas en el modelo de datos, pensado como la representacion 
de vista de diagrama y su esquema visual de tablas, relaciones y organizacion la interfaz para su interpretacion. 

Expresion DAX 

Aka: DAX Expression 


Es el conjunto de funciones y operadores que en union tienen como objetivo realizar una tarea especi'fica, es 
decir, es una formula creada con el lenguaje DAX. 


Filtro 


Aka: Filtro “Virtual” / Referenda 


Es el filtro aplicado a una tabla que tiene como fin segmentarla en un conjunto mas pequeno de acuerdo a la 
especificacion del mismo. 


Inteligencia de Negocios 

Aka: Business Intelligence / 8/ 


Es el conjunto de tecnicas, herramientas, procesos y metodos enfocadas en extraer, integrar, procesar y analizar 
datos (Generalmente cantidades masivas), para la creacion de informacion oportuna, de valor, precisa y accionable; 
que se convierta en conocimiento para la compama, con ello tomar decisiones que direccionen de forma positiva 
las acciones para alcanzar los objetivos de negocio. 


Iteration 

Aka: Loop / Bucle / Ciclo 


Es el proceso de ciclo que se repite ejecutando las mismas acciones en diferentes escenarios un numero 
determinado de veces, en las funciones DAX, es recorrer una fila de una tabla una a una ejecutando una accion. 


Iteration Multiple 

Aka: “Bucles Anidados” 


Es el proceso de ciclo que se repite ejecutando las mismas acciones en diferentes escenarios un numero 
determinado de veces anidado dentro de otro. 
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Jerarqufa 

Aka: Hierarchy 


Es un camino preestablecido en un reporte, creado a partir de la anidacion de varios niveles que estan 
relacionados entre si, para facilitar la busqueda y analisis de datos. 

Jerarqufa Padre/Hijo 

Aka: Hierarchy Parent/Child 


Son jerarquias que no tienen el mismo numero de niveles y existe una relacion padre/hijo entre sus elementos, 
puede visualizarse de manera aproximada como una relacion de arbol genealogico. 


KPI 


Aka: Key Performance Indicators 


Es una representacion grafica de la relacion que existe y que podemos definir a traves del modelo de datos, entre 
una medida y un valor fijo, o incluso otra medida establecida. 

Lenguaje DAX 

Aka: Lenguaje Funcional DAX 


El lenguaje DAX, es un lenguaje de formulas que permite crear calculos personalizados en tablas de Power Pivot 
para extraer informacion util para las compamas. Ademas, puede ser utilizado como lenguaje de consulta. 

Lenguaje De Consulta 

Aka: Query Lenguague 


Es un lenguaje informatico usado para hacer consultas en bases de datos y sistemas de informacion. 

Medida 

Aka: Campo Calculado en Excel 2013 I Measure 


Es una formula que resume datos numericos para realizar analisis dinamico 

Medida Implfcita 

Aka: Implicit Mesure 


Son aquellas medidas que se crean cuando arrastramos un campo de una tabla, al area de valores de una tabla 
dinamica. Por lo tanto, pueden ser algunas de las 10 funciones de resumen disponibles por defecto. 
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Medida Explicits 

Aka: Hierarchy 


Es una medida creada directamente con el lenguaje DAX, bien sea en el cuadro de dialogo medidas, en la barra 
de formulas DAX o en el area de medidas. 


Medidas Hibridas 

Aka: Hybird Measure 


Es un a medida que se ha creado con base en por lo menos dos medidas o columnas que pertenecen a distintas 
tablas base (Fact Table), por lo anterior, este tipo de medidas solo puede existir en un entretejido de tablas que 
tengan multiples bases bien relacionadas. 


Modelo de Datos 

Aka: Data Model 


El Modelo de Datos consiste en el conjunto de tablas, relaciones mediante declaraciones, Medidas, Columnas 
Calculadas, Jerarquias, KPIs y otros objetos creados en Power Pivot, para realizar analisis de datos orientado a 
Business Intelligence. 


Modelo de Datos Interno 

Aka: Internal Data Model 


El Modelo de Datos Interno son las posibilidades que tenemos en aquellas versiones de Office que no tiene el 
complemento de Power Pivot completo, sin embargo, con ello podemos utilizar una pequena parte de Power 
Pivot para crear modelos de datos sencillos basados en relaciones uno a muchos principalmente. 


Power Bl 


Aka: Power Bl (.com) / Power Bl en la Nube / Power Bl Desktop / Power Bl de Escritorio 


Es un software creado especificamente para transformar los datos de una compama en informacion rica para la 
toma de decisiones, une el poder del DAX Engine, Power Query Y Power View al cubo para lograrlo. 


Power Map 

Aka: Mapas 3D / 3D Maps / Geoflow (Era Conocido asi en su version Beta en el 2012) 


Es una funcionalidad de Excel que permite representar datos geograficos de forma bidimensional o tridimensional 
direcciones, codigo postal, paises, ciudades, vecindarios, calles y todo aquello que puedageo localizar en un mapa, 
ademas, de interaccion dinamica con datos temporales. 
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Power Pivot 

Aka: Gemini (En 2009) 


Es un potente motor de procesamiento de datos, que permite agrupar datos de multiples fuentes de una manera 
supremamente sencilla y a una velocidad sorprendente, “como a la velocidad de la luz”. Todo ello para obtener 
informacion de valor, accionable y oportuna para tomar decisiones en poco tiempo, todo mediante del lenguaje 
DAX. 

Power Query 

Aka: Obtener y Transformar / Data Explorer 


Es una funcionalidad que pone a nuestra disposicion las opciones suficientes para tomar Raw Data (datos no 
optimos para llevar acabo analisis acertados) consolidarlos, transformarlos, enriquecerlos, limpiarlos, estandarizarlos 
y adaptarlos para que queden de forma optima y hacer un posterior analisis. 

Power View 

Aka: Canvas 


Es una funcionalidad de Excel que permite tomar todo ese procesamiento de datos, donde se ha resumido y 
hecho los calculos para derivar informacion relevante y, presentarlo (Mostrarlo) mediante graficos, indicadores 
y distintas ayudas visuales para poder absorber la informacion de manera sencilla e intuitiva. 

Relacion 

Aka: Relationship 


Es la conexion creada entre una o mas tablas que han sido agregadas al modelo de datos, y se realiza con el 
objetivo de realizar analisis de datos. 


Reporte 

Aka: Report / Informe 


Son informes que clasifican y organizan informacion clave, extrafda de una base de datos 


Reporte de Tabla Dinamica 


Es un reporte creado a partir de la funcionalidad de tablas dinamicas de Excel, dejando la tabla de forma interactiva 
para resumir los datos en cuestion de segundos. 
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Reporte Parametrizable 

Aka: Reporte que Recibe Datos de Entrada del Usuario 


Es un tipo de reporte de tabla dinamica que permite al usuario suministrar parametros a una tabla dinamica a 
traves de un Slicer, con lo cual, puedes visualizar la informacion alii presentada de multiples maneras. 


Restriction 

Aka: Constrains 


Tambien conocidas como constrains, son alteraciones realizadas al query context a traves de diferentes funciones 
del lenguaje DAX. 


Snnipets 

Aka: Patterns / Patron • Termino t( Propio ,f Adaptado 


Formulas del lenguaje DAX reusables para otras situaciones, donde las modificaciones que hay que hacer son 
minimas para emplearlas en otros escenarios, este termino es usado en programacion de computadoras, pero 
en el texto se extienda a formulas DAX. En Power Pivot se les conoce como patrones. 


SSAS Tabular 

Aka: SQL Server Analysis Services Tabular / Modelado Tabular 


Los modelos tabulares son bases de datos "en memoria" de Analysis Services. Gracias a los algoritmos de 
compresion avanzados y al procesador de consultas multiproceso, el motor analitico en memoria xVelocity 
(VertiPaq) ofrece un acceso rapido a los objetos y los datos de los modelos tabulares para aplicaciones cliente 
de informes como Microsoft Excel y Microsoft Power View. 

Los modelos tabulares admiten el acceso a los datos mediante dos modos: modo de almacenamiento en cache y 
modo DirectQuery. En cache, puede integrar datos de varios origenes como bases de datos relacionales, fuentes 
de distribucion de datos y archivos de texto pianos. En DirectQuery, puede omitir el modelo en memoria, lo 
que permite a las aplicaciones cliente consultar los datos directamente en el origen relacional (SQL Server). 


Los modelos tabulares se crean en SQL Server Data Tools (SSDT) mediante las nuevas plantillas de proyectos 
de modelos tabulares. Puede importar datos de varios origenes y, a continuacion, enriquecer el modelo 
agregando relaciones, columnas calculadas, medidas, KPI y jerarquias. A continuacion, los modelos se pueden 
implementar en una instancia de Analysis Services que permite a las aplicaciones cliente de informes conectarse 
con ellos. Los modelos implementados se pueden administrar en SQL Server Management Studio del mismo 
modo que los modelos multidimensionales. Tambien se pueden crear particiones de los mismos para optimizar 
el procesamiento y protegerlos en el nivel de fila usando la seguridad basada en roles. 
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Tabla Base 

Aka: Tabla Matriz / Tabla de Hechos / Fact Table / Tabla Principal 


Es la tabla central de un esquema dimensional y contiene los valores de las medidas de negocio o dicho de otra 
forma los indicadores de negocio, es la tabla que tiene una o mas calves externas. 

Tabla de Busqueda 

Aka: Tabla de Dimension 


Son elementos que contienen atributos (o campos) que se utilizan para restringir y agrupar los datos almacenados 
en una tabla de hechos cuando se realizan consultas sobre dichos datos en un entorno, estas tablas tienen los 
atributos que identifican de forma unica las filas y tiene informacion acerca de las tablas en general. 

Tabla de Calendario 

Aka: Tabla de Fechas 


Son una especie particular de tablas de busqueda que tienen como objetivo permitir categorizar nuestros datos 
de multiples maneras, esto mediante columnas que segmentan en diversos grupos, como: Anos, meses, 
semestres. Etc. 


Tabla de Conexion 

Aka: Bridge Table 


Es una tabla que conecta la tabla de filtros intermedia con la Pseudo-tabla de busqueda, cuya finalidad es servir 
como puente para crear una relacion muchos a muchos en Power Pivot. 

Tabla Desconectada 

Aka: Tabla de Parametros 


Es una tabla que esta agregada en el modelo de datos pero que no se relaciona con ninguna otra tabla, y es 
utilizada para crear reportes parametrizables. 


Tabla De Filtros Intermedia 

Aka: Tabla de Categorias 


Es el campo por el cual queremos categorizar una tabla dinamica y extraer los valores unicos para construir una 
tabla que servira para arrastrar a las areas de colocacion. 
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Tabla de Pseudo Busqueda 

Aka: Broken Lookup Table 


Es una tabla que no tiene ninguna columna que pueda servir como clave principal, pero por la naturaleza de sus 
datos es proxima ser una tabla de busqueda. 


Tablas Intermedias 

Aka: Helper Tables 


Es un tipo de tabla que sirve como apoyo para construir y realizar acciones en otra tabla, principalmente utilizadas 
como via para crear relaciones muchos a muchos en Power Pivot. 


Tabla Sliers 

Aka: Tabla de Parametros 


Es un Slicer que contiene los diferentes parametros a aplicar en un reporte parametrizable y que, a su vez, ha 
sido creado a partir de una tabla agregada al modelo de datos pero que NO ha sido relacionada con ninguna 
otra dentro del modelo. 


Transition de Contexto 

Aka: Transition Context / Cambio de Contexto 


Es el proceso o tecnica mediante el cual se trasforma el contexto de fila en contexto de filtro, especialmente util 
para KPIS. 


OLAP Cubo 

Aka: OnLine Analytical Processing 


Es una base de datos multidimensional, en la cual el almacenamiento fi'sico de los datos se realiza en un vector 
multidimensional. Los cubos OLAP se pueden considerar como una ampliacion de las dos dimensiones de una 
hoja de calculo. Esto hace que el acceso a los datos sea supremamente veloz y semi construido. 
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nexo B 


Snnipets (Patrones) DAX) 


Introduccion 


En este anexo podras encontrar algunas medidas reusables de manera directa, a lo que 
llamamos Snippets en este libro. 
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Mediana Para Excel 2013 


TU_TABLA[Mediana Excel 2013]:= 

( 

MINX ( 

FILTER ( 

VALUES ( TABLA_Pedidos[Precio de Venta] ); 

CALCULATE ( 

COUNT ( TABLA_Pedidos[Precio de Venta] ); 

TABLA_Pedidos[Precio de Venta] <= EARLIER ( TABLA_Pedidos[Precio de Venta] ) 

) 

> COUNT ( TABLA_Pedidos[Precio de Venta] ) / 2 

); 

TABLA_Pedidos[Precio de Venta] 

) 

+ MINX ( 

FILTER ( 

VALUES ( TABLA_Pedidos[Precio de Venta] ); 

CALCULATE ( 

COUNT ( TABLA_Pedidos[Precio de Venta] ); 

TABLA_Pedidos[Precio de Venta] <= EARLIER ( TABLA_Pedidos[Precio de Venta] ) 

) 

> ( COUNT ( TABLA_Pedidos[Precio de Venta]) - I ) 

12 

); 

TABLA_Pedidos[Precio de Venta] 

) 

) 

12 


• TABLA_Pedidos[Precio de Venta]: Donde aparezca esto, debes reemplazarlo por la columna a la 
cual deseas hallar la mediana. 





Anexos 429 


Media Movil para Excel 2016 y 2013 


TU_TABLA[Media Movil Siete Dias]:= 

AVERAGEX ( 

FILTER ( 

ALL ( Calendario[Fecha]); 

Calendario[Fecha] 

> ( MAX ( Calendario[Fecha] ) - 7 ) 

&& Calendario[Fecha] <= MAX ( Calendario[Fecha] ) 

); 

[Costo Total Ite] 

) 

• Calendario[Fecha]: Donde aparezca esto, debes reemplazarlo por tu columna de fecha en tu tabla 
de calendario (tabla de fechas) 

• 7 : Si deseas cambiar el numero de dias para la media movil, puedes hacerlo modificando el numero 
siete por el que desees. 

• [Costo Total Ite]: Aqui debes reemplazarlo por la medida que deseas calcular la media movil. 


Moda para Excel 2016 y 2013 


[Moda para Excel 2016 y 2013] := 

MINX ( 

TOPN ( 

I; 

ADDCOLUMNS ( 

VALUES ( TABLA_Pedidos[Precio de Venta]), 

"Freciencia"; CALCULATE ( COUNT ( TABLA_Pedidos[Precio de Venta ]) ) 

); 

[Frecuencia]; 

0 

); 

TABLA_Pedidos[Precio de Venta] 

) 
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nexo C 


Herramientas y Referencias 


Introduccion 


Existen diversas herramientas y recursos, tanto de pago como gratuitas que nos ayudan a 
trabajar con Power Pivot y el lenguaje DAX de manera mas amigable, divertida y acertada; 
donde ademas podemos lograr tareas que de otro modo tomarfan mucho tiempo. En este 
anexo queremos hacer referencias a tres grandiosas herramientas gratuitas que puedes 
encontrar y descargar en la web, para empezar a implementar ahora mismo, estas son: 


• DAX Formatter 

• DAX Studio 


• Power Pivot Utilities 
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HERRAMIENTAS 


DAX Formatter 

Web: http://www.daxformatter.com/ • SQL Bl Team 


Cuando se empieza a dominar DAX, aprender a crear formulas largas es facil, de hecho, se empieza a volver 
comun ya que en nuestra labor para extraer insights lo requiere y se vuelve 100% natural para nosotros, es por 
ello, existen ciertas reglas para darle un formato a las formulas DAX, como se menciono, en el capitulo 6, de tal 
manera que sea facilmente interpretable tanto por terceros como para nosotros. 

Con esto en mente, el equipo de SQL Bl t liderado por Marco Russo y Alberto Ferrari crearon la maravillosa utilidad 
On-Line llamada DAX Formatter. 


fflsqlbi 

(f? DAX 

Patterns 

DAY -6 SYNOPTIC 

L/MA "V DESIGNER 

FORMATTER 

DAX 

FORMATTER 

SEPARATORS 

US/UK (A, B r C | 1.234) < > HTML ONLY LIGHT THEME 

^ BUG REPORT 


FORMAT 


Ilustracion C. / - DAX Formatter Utilidad On-Line 


Para Acceder a ella solo tienes que ir a esta URL: http://www.daxformatter.com/ (Es 100% Gratuita) 


• Su uso es bastante sencillo intuitivo, por ejemplo, si tomamos la medida Erogaciones Apropiadas de 
Producto al final creada en el capitulo 8: 


CALCULATE ( SUM ( TABLA_Pedidos[Precio de Venta] ), FILTER ( TABLA_Pedidos } 
TABLA_Pedidos[Costo del Producto] 

<TABLA_Pedidos[Costo de Envio]+TABLA_Pedidos[Costo Empaque] ) 

) 
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Copiar y pegar la medida en el DAX Formatter. 


KB sqlbi 

[UgnAx UBdax 

DAX -i SYN0PT,C 

I v designer 

FORMATTER 



SEPARATORS US/UK (A. B, C | 1.234) <> HTML ONLY -)5(- LIGHT THEME 

DAX 

FORMATTER 

= CALCULATE 

) 

) 

( SUM ( TABLA_Pedidos[Precio de Venta] ), FILTER ( TABLA_Pedidos, 
TABLA_Pedidos[Costo del Producto] 

<TABLA_Pedidos[Costo de Envio]+TABLA_Pedidos[Costo Empaque] 

BUG REPORT 


FORMAT 


Ilustracion C. II - Ahadiendo Formula DAX al DAX Formatter 


Pulsamos clic en el boton FORMAT y listo: 


KB sqlbi 

ICbax DAX 4 SYNO r"< 

FORMATTER 

DAX 


SEPARATORS US/UK (A. B, C | 1.234) <> HTML ONLY -)c£- LIGHT THEME 

FORMATTER 

CALCULATE 


SUM 

TABLA_Pedidos[Precio de Venta] , 


FILTER ( 

^ BUG REPORT 


TABLA_Pedidos, 

TABLA_Pedidos[Costo del Producto] 

< TABLA_Pedidos[Costo de Envio] + TABLA_Pedidos[Costo Empaque] 

COPY COPY HTML SAVE AS DOCX EDIT NEW 


Ilustracion C. Ill - Formula DAX bien formateadas con DAX Formatter 


Ahora la formula queda debidamente formateada, podemos utilizar el boton COPY en la parte inferior 
izquierda para utilizarlo donde necesitamos, el cuadro de dialogo medidas, Power Bl, etc. 


;NOTA! 





El DAX Formatter reconoce como separador de lista el caracter coma (,) por defecto, si 
utilizas (;) debes cambiar las opciones de SEPARATOR que se encuentran en la parte superior 
derecha antes de pegarlo en la utilidad Online, sino saldran errores. Las reglas que sigue el 
DAX Formatter son las mencionadas en el capitulo 6, igualmente en la parte inferior de la 
pagina se encuentra el link donde los autores las especifican. 
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DAX Studio 

Web: https://daxstudio.codeplex.com/ Codeplex 


DAX Studio es otra herramienta gratuita y fantastica, con ella podemos hacer consultas a las tablas de Power 
Pivot de manera directa y amigable, cuenta con una interfaz estupenda y una serie de opciones que nos permite 
llevar acabo ciertas acciones que tarde o temprano necesitaremos y nos ahorraran muchisimo tiempo. 

Hay multiples cosas que podemos conseguir con DAX Studio, a continuacion, listamos las mas relevantes: 

• Extraer lisa de Medidas de tu Modelo de Datos 

• Para Ver el Global 

• Para Documentacion 

• Ayuda a Crear Formulas DAX Complejas 

• Facilidad para Aprender a Crear Consultas 


■ ■Mil 

STUDIO 


jNOTA! 

DAX Studio siempre retorna una tabla, lo cual es lo opuesto a una medida en Power Pivot que 
debe ser une escalar para poder mostrarlo en la tabla dinamica, esto es muy importante para 
analizar partes de formulas donde se devuelven tablas y detector que si es retornando lo que 
deseamos. 


Para DESCARGARLO, solamente vista esta web: https://daxstudio.codeplex.com/ y clic en el boton 
Download 



llustracion C. IV - Descargar DAX Studio 
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Despues de descargarlo e instalar DAX Studio, se debe ACTIVAR en complementos COM, son exactamente 
los mismos pasos que se siguen para activar Power Pivot (Capitulo 3) pero esta vez se selecciona DAX Studio 
Excel Add-in y aceptar. 


? X 

Aceptar 

Cancelar 

Agregar... 

guitar 


Ubicacion: f i I e :///C:/Pro g ra m Files/D AX 5tudio/DaxStudio.vsto|vsto local 

Comportamiento de carga; Cargar al inicio 


Complementos COM 


Complementos disponibles: 



Adobe Contribute Plugin 


V 

Dax Studio Excel Add-In H 


Inquire 



Microsoft Power Map for Excel 



Microsoft Power Pivot for Excel 



Microsoft Power View for Excel 


- 

PDF Architect 4 Excel plugin 

V 


llustracion C.V- Activar DAX Studio en Complementos COM 


Ahora aparcera una pestana llama DAX Studio, el siguiente paso es ejecutar el comando DAX Studio en dicha 
pestano o ejecutarlo desde el acceso directo que generan el escritorio del pc, esto abre una venta que pide 
conexion, por defecto aparecera Power Pivot Model con el archivo de Excel actual que tenga modelo de datos. 


Connect 


Data Source 

@ Power Pivot Model 

Anexo ELxIsx 

O Tabular Server 




v Advanced Options 


Connect 


Cancel 


llustracion C. VI - Interfaz de DAX Studio 
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Power Pivot Utilities 

Web : http://www.sqlbi.com/tools/power-pivot-utilities/ * SQL 8/ Team 


Power Pivot Utilities es un complemento para Excel que ayuda a documentar los modelos de datos en Excel. Es 
un complemento que se instala y crear una nueva pestana en la cinta de opciones de Excel, ademas, este 
complemento nos brinda acceso a DAX Formatter y DAX Studio. 


Archivo 

Inicio Insertar Diseho t Formula Datos Revisar Vista Desarrol Power P 

PP UTIL 

0 Indicar 

Com pa 



Insert List table List List calculated List unused Model Format DAX 
Pivottable relationships measures columns columns memory usage expressions 


w 

Dax 

Studio 


©Help 

© Check for updates 


Power Pivot utilities 


Help 


llustracion C. VII - Pestana PP UTILITIES 


Si pulsamos clic, por ejemplo, en comando List Measures, crea una tabla con todas las medidas en el modelo de 
datos, tanto sus nombres y formulas, como a las tablas las que pertenecen. 


TABLE Q MEASURE 

□ DAX Expression 

□1 

Produccion Unidades Provei'das 

:=[Cantidades]-[Unidades Ventas] 


Produccion Cantidades 

:=CALCULATE(SUMCProducci6n'[Cantidad]),'Producci6n'[Bodega]="AII Out") 


SKU Productos Recuento de SKU 2 

:=COUNTACSKU Productos'[SKU]) 


TABLA_Pedidos Tasa Basica de Crecimiento 

:=IF(COUNTROWS(VALUES(TABLA_Pedidos[Fecha de Envio (ano)]))=l, 
IF(VALUES(TABLA_Pedidos[Fecha de Envio (ano)])=" 1999", 

BLANKO, 

DIVIDE( 

[Ingresos] - [Ingresos Primer Ano Completo 2000], 

[Ingresos Primer Ano Completo 2000] 

) 



). 

BLANKO 

) 


TABLA_Pedidos Ingresos Tipicos 

:=CALCULATE([lngresos],TABLA_Pedidos[Categona de Descuento]="Non" || TABLA_Pedidos[Categoria de 
Descuento]="Day Off FuM",TABLA_Pedidos[Tipo de Compra]="Normar) 

TABLA_Pedidos % Ingresos Respecto al Total 

:=[lngresos]/ 

CALCU LATE([I ngresos], ALL(TABLA_Ped idos)) 


TARI A P ~A.A~r Pr-irv^.- Anr. r'n.nnW.r. Oflfkfl 

■=r"Ai n n ATcrn^^^^^i tari a 



llustracion C. VIII - Tabla de Medidas 


De la misma forma tenemos comandos para crear una tabla que nos liste las columnas calculadas en uso, las 
que no estan en uso y las relaciones. 
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llustracion C. IX - Columnas Calculadas 




1 TABLA_PedidQ5 

SKU 

SKU Producto5 

SKU 

VERDADERO 

2 TABLA Pedido5 

Categoria de Descuento 

Descuentos 

Cat ego ria d e D e 5 c u e nt o 

VERDADERO 

3 TABLA Pedidos 

SKU 

TAB LACatego riaD e Pro d u cto 5 

SKU 

VERDADERO 

A TABLA Pedido5 

Fecha de Envio 

Calendario 

Fecha 

VERDADERO 

5 TABLA Pedidos 

Fecha de Llegada 

Calendario 

Fecha 

FALSO 

6 Produccion 

SKU 

TAB LA Catego riaD e Pro d u cto 5 

SKU 

VERDADERO 

7 Produccion 

SKU 

SKU Producto5 

SKU 

VERDADERO 

8 Produccion 

Fecha 

Calendario 

Fecha 

VERDADERO^ 


Primary Key column Q Active 


ID U Foreign Key Table Q Foreign Key Column Q Primary Key Table 


llustracion C. X - Tabla de Relaciones 


Tambien, centra con comandos para mirar cuanta memoria esta utilizando el modelo de datos de cada tabla y 
un comando para crear una tabla dinamica, especialmente util para las versiones de Excel 2013. 


TABLE Q COLUMIQ DataTypQ Memory | 


TABLA_Categ _XL_Rowh DBTYPE_I4 0.09 

TABLA_Categ SKU DBTYPE W' 16.99 


TABLA_Pedidt Categoria de DBTYPE_W' 


16.53 


Etiquetas de flla 


3dTABLA Pedidos 


[ T i Sum of Memory Size (KI 
I 257.1 


TABLA_Categ Categoria DBTYPE_W' 

16.48 

+ BasicCalendarEnglish 

854.) 

TABLA_Categ Precio de Ve DBTYPE_R8 

0.09 

[+ Calendario 

439. 

TABLA_Pedid._XL_Rowh DBTYPEJ4 

0.09 

[+ Produccion 

56.: 

TABLA Pedid* Numero de F DBTYPE_R8 

0.09 

ffl SKU Productos 

40. 

TABLA_Pedid.Tipo de Corr DBTYPE_W 

16.44 

ffl T ABLA_CategorfaDeProductos 

33. 

TABLA_Pedid. SKU DBTYPEW 1 

16.72 

[+ Descuentos 

16. 


Total general 


2 699.- 
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REFERENCIAS 


Nosotros hemos aprendido Power Pivot, construction de modelos de datos y el lenguaje DAX 
gracias a la gran variedad de formaciones y recursos que han desarrollado y publicado los 
mismos creadores de Power Pivot y otros grandes expertos en el area, gracias a sus: Workshops, 
Webinars, Mentoring y libros; este texto fue posible, donde tematicas de este texto en diversos 
momentos se basan directamente en contenido de estas grandes personas. 

En esta parte te queremos dejar todos los libros que, a lo largo de los ultimos ahos, nosotros lo 
autores del presente texto hemos adquirido y estudiado para profundizar, interiorizar e indagar 
en el lenguaje DAX y la construccion de modelos de datos sofisticada. Todos los libros descritos 
inmediatamente son magia pura y de cada uno de ellos podras aprender diferentes cosas y 
utilidades extraordinarias; es importante, advertir que todos ellos estan en ingles, pero no dejan 
de ser obras de la mayor relevancia en todo el mundo. 


Agradecemos de todo corazon a: 


Rob Collie, Avichal Singh, Bill Jelen, Marco Russo, Alberto Ferrari, Matt Allington, 
Kasper de Jonge Y Christopher Webb. 
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Power Pivot and Power Bl: The Excel User's Guide for DAX 

Rob Collie & Avichal Singh • En: http://goo.gl/qYT2RZ • Power Pivot Pro 


Unos de los mejores libros sobre Power Pivot en el mercado, su sencillez y forma amena de abordar las tematicas 
lo hace facil de absorber, es un libro que va desde cero hasta aspectos avanzados, una de las mejores gui'as, 
referencias y metodos de aprendizaje que nosotros los autores de este texto hemos seguido. 

Microsoft Excel 2013 Building Data Models With Power Pivot 

Alberto Ferrari & Marco Russo • En: http://goo.gl/031 qd8 • SQL Bl 


jUna obra maestra!, al igual que libro de Rob Collie, empieza desde cero hasta avanzado, justo para encontrar 
otras tematicas para expandir las posibilidades en la construccion de Modelo de Datos. Otras de las guias 
imprescindibles para nosotros los autores en aprendizaje practica y profundizacion en el lenguaje DAX. 

Learn To Write DAX: A Practical Guide To Learning Power Pivot 

Matt Allington • En: http://goo.gl/SR9nnr Excelator Bl 


Este libro nos sirvio especialmente para ver desde otra perspectiva y con otra narracion el lenguaje DAX, asi 
como poner en practica el lenguaje, ya que trae ejercicios interesantes. 

Power Pivot Alchemy: Patterns and Techniques 

Rob Collie & Bill Jelen • En: http://goo.gl/TtEivB • Power Pivot Pro 


Un excelente libro para dar otro paso, mediante el aprendizaje y utilizacion de patrones (Snippets), buenas 
practicas y tecnicas para cuadros de mando, si deseas dar otro paso despues del presente texto o los anteriores 
descritos aqui, esta es buena opcion. 


DAX Patterns 2015 


Alberto Ferrari & Marco Russo • En: http://goo.gll695jEY • SQL Bl 


^Quieres un libro llene de patrones (Snnipets) listos para utilizar?, entonces este tienes que anadirlo a tu libreria, 
cuenta con Snnipets para estadisticas, analisis ABC, Secuencia En el tiempo, inventarios, agregados, etc. Etc. 

PowerPivot For Data Analysis 

Bill Jelen • En: http://goo.gl/wKDULX « Mr Excel 


El primer libro escrito en el mundo sobre PowerPivot, una obra que nos llevo a conocer este maravilloso mundo, 
y con el cual dimos nuestros primeros pasos, una obra clasica, enriquecedora y de coleccion. 


Dashboarding and Reporting With Power pivot 

Kasper de Jonge * En: http://goo.gl/95U65i 
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ELADN 

DE POWER PIVOT 


Power Pivot, el modelo de datos y de por si el DAX Engine es la herramienta mas poderosa, 
completa y robusta que uno persona que no sea un IT altamente especializado debe tener en 
su caja de herramientas, es decir, cualquier usuario de Excel. 

Power Pivot proporciona un sinfrn de herramientas y alternativas para manejar cantidades 
masivas de datos de multiples orfgenes de una manera supremamente sencilla y rapida 
“como a la velocidad de la luz”, con lo cual podemos realizar analisis mediante calculos 
personalizados que solamente estan limitados por nuestra imaginacion, es una herramienta 
tan poderosa que como dicen los gurus: “Son 20 anos de perfeccionamieVo y desarrollo 
puesto nuestra disposicion el di'a de hoy”, dominar Power Pivot y el lenguaje€AX es lo mejor 
que una persona puede hacer hoy en dia pues no solamente representara un diferencial 
importante en el ambito laboral al tener la capacidad de integrar y analizar cantidades 
masivas de datos, sino la pieza para escalar y tomar decisiones mas precisas. 


Miguel Caballero es formador y consultor en analisis de datos utilizando Excel y Microsoft Bl, 
escritor del sitio web EFB y co-autor del libro Tablas Dinamica La Quinta Dimension junto con 
Fabian Torres. 

Fabian Torres es creador de contenido en EFB y consultor en Business Intelligence, experto en 
visualizacion de datos y graficos avanzados. 


Sobre la Coleccion ADN 

La coleccion ADN de EFB es un conjunto de 
libros encaminados a inteligencia de negocios, 
para ello recorre las herramientas de Microsoft 
Business Intelligence o “Self Services Bl” con el 
objetivo de brindar el arsenal necesario para 
extraer buenas decisiones basada en informa- 
cion obtenida de cantidades masivos de datos 
(Big Data) para y asi direccionar los objetivos de 
negocios de manera oportuna, accionable y con 
un fuerte valor agregado. 
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